| 查看: 2063 | 回复: 20 | ||
| 当前只显示满足指定条件的回帖,点击这里查看本话题的所有回帖 | ||
[求助]
一下的数据如何通过C++读取
|
||
|
数据文件例子:test.txt Frame 3.0 12.0 20.0 1.0 7.0 7.0 15.0 21.0 4.0 Frame 2.0 2.0 15.0 1.0 12.0 3.0 11.0 2.0 23.0 Frame 2.0 21.0 15.0 11.0 12.0 13.0 11.0 2.0 23.0 例子中共有k(k=3)组数据,每组数据n行(n=3),m列(n=3)。 想把它读入a1[k][n],a2[k][n],a3[k][n]数组中,用二维数组保存,要求数组第一个下标对应的是组数k,而第二个下标对应的是行数n,数组名已经区分了列数(实际中代表不同类型的数据,所以用不同数组明区分,后面好进行处理),这里是3列所有用了三个数组a1,a2,a3。 多谢高手指点。 |
» 猜你喜欢
球磨粉体时遇到了大的问题,请指教!
已经有11人回复
江汉大学解明教授课题组招博士研究生/博士后
已经有3人回复

zeppe
金虫 (小有名气)
- 应助: 15 (小学生)
- 金币: 3901.3
- 散金: 58
- 红花: 4
- 帖子: 205
- 在线: 254.1小时
- 虫号: 573594
- 注册: 2008-06-14
- 性别: GG
- 专业: 理论和计算化学
【答案】应助回帖
|
1.我发现如果输入文件(test.txt)中只加入第1,8,15,22行(对应ITEM: TIMESTEP),并在代码中加入下列代码行: if(line == "ITEM: TIMESTEP" { continue; } 程序能够正常运行,并输出正确结果。 2.如果再加入第2,9,16,23行(对应16000.0),并加入相应代码 double vab; std::istringstream iss1(line); iss1 >> vab; vt.push_back(vab); 程序却不能正确运行,输出的错误为: assert(vals.size() == 64); 此行有问题,如果我注视掉将出现错误结果。 不知道为什么? === 楼主你好,程序是要根据文本的格式作变化的,你改了格式之后应该尽量让程序不会出现误判的情况。 原来只有Frame一行是字符,其他都是要用的数字,要考虑的条件很少,所以可以那样写。 现在改了格式了,就要加限定条件,让计算机认准地方。 注意到 16000.0是夹在ITEM: TIMESTEP 和 Atoms 这两行之间的,出现了好几次,那么这个值在这个文本文件中如果一直不变,就可以用一个数值变量存储,不然就要用数组/vector存储。 假设这个16000.0是可能变化的,并且一直夹在ITEM: TIMESTEP 和 Atoms 这两行之间 那么可以这样读入: 以上没有测过,我下班了,如果有问题明天再说。 |
16楼2013-06-03 18:22:02
2楼2013-06-02 18:54:02
【答案】应助回帖
★
xzhdty: 金币+1, 谢谢参与 2013-06-02 20:49:07
xzhdty: 金币+1, 谢谢参与 2013-06-02 20:49:07
|
#include<iostream> #include<fstream> using std::cout ; int main() { const char *filename = "test.txt 所在的绝对路径" ; std::ifstream is(filename ) ; double a1[3][3] = {0} ; double a2[3][3] = {0} ; double a3[3][3] = {0} ; for (int k = 0 ; k != 3 ; ++k) for (int n = 0 ; n != 3 ; ++n) { //is >> data ; switch(n) { case 0 : is >> a1[k][n] >> a2[k][n] >> a3[k][n]; break ; case 1 : is >> a1[k][n] >> a2[k][n] >> a3[k][n] ; break ; case 2 : is >> a1[k][n] >> a2[k][n] >> a3[k][n] ; break ; } } for (int k = 0 ; k != 3 ; ++k) //为了测试正确性 35 for (int n = 0 ; n != 3 ; ++n) 36 { 37 cout << a1[k][n] << "\t" << a2[k][n] << "\t" << a3[k][n] << std::endl ; 38 } return 0 ; } |
3楼2013-06-02 20:25:07

4楼2013-06-02 21:14:37













回复此楼
mljphy