[英]Extracting string data from text C++
我目前正在編寫一個需要從文本文件中提取字符串和數字數據的c ++程序。 數據格式如下;
3225 C9+ ELECTR C8 C * 1.00E-6 -0.30 0.0
第一個條目是整數,接下來的5個條目是字符串,最后3個是浮點數。 沒有字符串長度超過7個字符。
我正在逐行讀取文件,然后使用提取數據;
sscanf(ln.c_str(),"%d %s %s %s %s %s %e %e %e",
&rref[numre],&names[numre][0],&names[numre][1],&names[numre][2],&names[numre][3],
&names[numre][4],&nums[numre][0],&nums[numre][1],&nums[numre][2]);
這很好用,直到我遇到一條線;
3098 SIC2H3+ ELECTR SIC2H2 H * 1.50E-7 -0.50 0.0
其中一個托盤是完整的7個字符長。 在這種情況下,我得到;
names[3097][0] = "SIC2H3+ELECTR"
和,
names[3097][1] = "ELECTR"
任何人都有任何想法...他們將不勝感激!
最可能的問題是在names
聲明中:如果你聲明它持有7個字符或更少,並且忘記分配空間來終止零,你將獲得你正在描述的結果。
char names[MAX][4][7]
將有足夠的空間用於長度為6或更短的字符串; 對於長度為7的字符串,您需要
char names[MAX][4][8]
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.