热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

C++从文件中逐行读取结构体数据,并将其存储到向量中,最终输出至控制台和新文件

在C++程序中,文档A的每一行包含一个结构体数据,其中某些字段可能包含不同数量的数字。需要将这些结构体数据逐行读取并存储到向量中,随后不仅在控制台上显示,还要输出到新创建的文档B中。希望得到指导,感谢!
c++


文档A中每一行都是一个struct,最后几个数字的数量是不一定的,需要把每一行都放入vector然后输出到屏幕,并且也输出到新建的文档B中。求指教,谢谢! 

struct hero
{
  string name;
  int age;
  char sex;
  double weight;
  string color;
  vector number;
};

4 个解决方案

#1


没有找到你提的问题,你是要请人帮你完成这个任务?还是任务中碰到了什么问题?

#2


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
// CPP文件读写.cpp : 定义控制台应用程序的入口点。<br>
//<br>
<br>
#include "stdafx.h"<br>
#include <iostream><br>
#include <fstream><br>
#include <strstream><br>
#include <string><br>
#include <vector><br>
using namespace std;<br>
<br>
const string inFileName="testData.txt";<br>
const string outFileName="outData.txt";<br>
<br>
struct Hero<br>
{<br>
    string name;<br>
    int age;<br>
    char sex;<br>
    double weight;<br>
    string color;<br>
    vector<int> number;<br>
};<br>
<br>
vector<hero> heroList;<br>
<br>
int _tmain(int argc, _TCHAR* argv[])<br>
{<br>
    ifstream fin;<br>
    fin.open(inFileName.c_str(),ios::in);<br>
    if(!fin.is_open())<br>
    {<br>
        cout<<"打开文件"<<infilename<<"失败。"<<endl;<br>
        exit(1);<br>
    }<br>
<br>
    ofstream fout;<br>
    fout.open(outFileName.c_str(),ios::out);<br>
    if(!fout.is_open())<br>
    {<br>
        cout<<"创建文件"<<outfilename<<"失败。"<<endl;<br>
        exit(1);<br>
    }<br>
<br>
    string line;<br>
    getline(fin,line);<br>
    while(line.length()>0) //>20<br>
    {<br>
        istrstream ss(line.c_str());<br>
        Hero aHero;<br>
        ss>>aHero.name>>aHero.age>>aHero.sex>>aHero.weight>>aHero.color;<br>
        cout<<ahero.name<<'\t'<<ahero.age<<'\t'<<ahero.sex<<'\t'<<ahero.weight<<'\t'<<ahero.color;<br>
        fout<<ahero.name<<'\t'<<ahero.age<<'\t'<<ahero.sex<<'\t'<<ahero.weight<<'\t'<<ahero.color;<br>
<br>
        int num;<br>
        do<br>
        {<br>
            ss>>num;<br>
            aHero.number.push_back(num);<br>
            cout<<'\t'<<num;<br>
            fout<<'\t'<<num;<br>
        }while(ss.good());<br>
<br>
//      ss.clear();<br>
        cout<<endl;<br>
        fout<<endl;<br>
        heroList.push_back(aHero);<br>
        getline(fin,line);<br>
    }<br>
<br>
    fin.close();<br>
    fout.close();<br>
    return 0;<br>
}<br>
<br>
</endl;<br></endl;<br></num;<br></num;<br></ahero.name<<'\t'<<ahero.age<<'\t'<<ahero.sex<<'\t'<<ahero.weight<<'\t'<<ahero.color;<br></ahero.name<<'\t'<<ahero.age<<'\t'<<ahero.sex<<'\t'<<ahero.weight<<'\t'<<ahero.color;<br></outfilename<<"失败。"<<endl;<br></infilename<<"失败。"<<endl;<br></hero></int></vector></string></strstream></fstream></iostream>

#3


修改了一下,
while(line.length()>0) //>8 最小长度可能是9,包括5个字段,4个Tab字符或者空格
还有,后面不定数量的数字可能是0个,改成 while(ss.good())
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
// CPP文件读写.cpp : 定义控制台应用程序的入口点。<br>
//<br>
<br>
#include "stdafx.h"<br>
#include <iostream><br>
#include <fstream><br>
#include <strstream><br>
#include <string><br>
#include <vector><br>
using namespace std;<br>
<br>
const string inFileName="testData.txt";<br>
const string outFileName="outData.txt";<br>
<br>
struct Hero<br>
{<br>
    string name;<br>
    int age;<br>
    char sex;<br>
    double weight;<br>
    string color;<br>
    vector<int> number;<br>
};<br>
<br>
vector<hero> heroList;<br>
<br>
int _tmain(int argc, _TCHAR* argv[])<br>
{<br>
    ifstream fin;<br>
    fin.open(inFileName.c_str(),ios::in);<br>
    if(!fin.is_open())<br>
    {<br>
        cout<<"打开文件"<<infilename<<"失败。"<<endl;<br>
        exit(1);<br>
    }<br>
<br>
    ofstream fout;<br>
    fout.open(outFileName.c_str(),ios::out);<br>
    if(!fout.is_open())<br>
    {<br>
        cout<<"创建文件"<<outfilename<<"失败。"<<endl;<br>
        exit(1);<br>
    }<br>
<br>
    string line;<br>
    getline(fin,line);<br>
    while(line.length()>0) //>8<br>
    {<br>
        istrstream ss(line.c_str());<br>
        Hero aHero;<br>
        ss>>aHero.name>>aHero.age>>aHero.sex>>aHero.weight>>aHero.color;<br>
        cout<<ahero.name<<'\t'<<ahero.age<<'\t'<<ahero.sex<<'\t'<<ahero.weight<<'\t'<<ahero.color;<br>
        fout<<ahero.name<<'\t'<<ahero.age<<'\t'<<ahero.sex<<'\t'<<ahero.weight<<'\t'<<ahero.color;<br>
<br>
        int num;<br>
        while(ss.good())<br>
        {<br>
            ss>>num;<br>
            aHero.number.push_back(num);<br>
            cout<<'\t'<<num;<br>
            fout<<'\t'<<num;<br>
        }<br>
<br>
//      ss.clear();<br>
        cout<<endl;<br>
        fout<<endl;<br>
        heroList.push_back(aHero);<br>
        getline(fin,line);<br>
    }<br>
<br>
    fin.close();<br>
    fout.close();<br>
    return 0;<br>
}<br>
<br>
</endl;<br></endl;<br></num;<br></num;<br></ahero.name<<'\t'<<ahero.age<<'\t'<<ahero.sex<<'\t'<<ahero.weight<<'\t'<<ahero.color;<br></ahero.name<<'\t'<<ahero.age<<'\t'<<ahero.sex<<'\t'<<ahero.weight<<'\t'<<ahero.color;<br></outfilename<<"失败。"<<endl;<br></infilename<<"失败。"<<endl;<br></hero></int></vector></string></strstream></fstream></iostream>

#4


应该用
istringstream ss(line);
代替
istrstream ss(line.c_str());
头文件由strstream 改成 sstream
更好一点,用的不熟凭印象都混了。

推荐阅读
  • 题目Link题目学习link1题目学习link2题目学习link3%%%受益匪浅!-----&# ... [详细]
  • 本文详细探讨了VxWorks操作系统中双向链表和环形缓冲区的实现原理及使用方法,通过具体示例代码加深理解。 ... [详细]
  • 题目描述:给定n个半开区间[a, b),要求使用两个互不重叠的记录器,求最多可以记录多少个区间。解决方案采用贪心算法,通过排序和遍历实现最优解。 ... [详细]
  • UNP 第9章:主机名与地址转换
    本章探讨了用于在主机名和数值地址之间进行转换的函数,如gethostbyname和gethostbyaddr。此外,还介绍了getservbyname和getservbyport函数,用于在服务器名和端口号之间进行转换。 ... [详细]
  • 本文详细介绍了如何构建一个高效的UI管理系统,集中处理UI页面的打开、关闭、层级管理和页面跳转等问题。通过UIManager统一管理外部切换逻辑,实现功能逻辑分散化和代码复用,支持多人协作开发。 ... [详细]
  • 扫描线三巨头 hdu1928hdu 1255  hdu 1542 [POJ 1151]
    学习链接:http:blog.csdn.netlwt36articledetails48908031学习扫描线主要学习的是一种扫描的思想,后期可以求解很 ... [详细]
  • 本题涉及一棵由N个节点组成的树(共有N-1条边),初始时所有节点均为白色。题目要求处理两种操作:一是改变某个节点的颜色(从白变黑或从黑变白);二是查询从根节点到指定节点路径上的第一个黑色节点,若无则输出-1。 ... [详细]
  • Codeforces Round #566 (Div. 2) A~F个人题解
    Dashboard-CodeforcesRound#566(Div.2)-CodeforcesA.FillingShapes题意:给你一个的表格,你 ... [详细]
  • 本题通过将每个矩形视为一个节点,根据其相对位置构建拓扑图,并利用深度优先搜索(DFS)或状态压缩动态规划(DP)求解最小涂色次数。本文详细解析了该问题的建模思路与算法实现。 ... [详细]
  • 本次考试于2016年10月25日上午7:50至11:15举行,主要涉及数学专题,特别是斐波那契数列的性质及其在编程中的应用。本文将详细解析考试中的题目,并提供解题思路和代码实现。 ... [详细]
  • 深入理解Redis的数据结构与对象系统
    本文详细探讨了Redis中的数据结构和对象系统的实现,包括字符串、列表、集合、哈希表和有序集合等五种核心对象类型,以及它们所使用的底层数据结构。通过分析源码和相关文献,帮助读者更好地理解Redis的设计原理。 ... [详细]
  • 本题旨在通过给定的评级信息,利用拓扑排序和并查集算法来确定全球 Tetris 高手排行榜。题目要求判断是否可以根据提供的信息生成一个明确的排名表,或者是否存在冲突或信息不足的情况。 ... [详细]
  • Linux设备驱动程序:异步时间操作与调度机制
    本文介绍了Linux内核中的几种异步延迟操作方法,包括内核定时器、tasklet机制和工作队列。这些机制允许在未来的某个时间点执行任务,而无需阻塞当前线程,从而提高系统的响应性和效率。 ... [详细]
  • 在多线程编程环境中,线程之间共享全局变量可能导致数据竞争和不一致性。为了解决这一问题,Linux提供了线程局部存储(TLS),使每个线程可以拥有独立的变量副本,确保线程间的数据隔离与安全。 ... [详细]
  • 实体映射最强工具类:MapStruct真香 ... [详细]
author-avatar
miedao1592_460
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有