簡體   English   中英

從文本C ++中提取字符串數據

[英]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.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM