这篇文章将为大家详细讲解有关c++如何实现文件逐行读取与字符匹配,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。C++读取文件首先我们构造一个txt文件用于测试,比如以下这个名为mindspore.txt的
这篇文章将为大家详细讲解有关c++如何实现文件逐行读取与字符匹配,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
首先我们构造一个txt文件用于测试,比如以下这个名为mindspore.txt的文件(之所以取这个名字,是因为最近在研究mindspore,因此最方便拿到的数据就是mindspore的借口api文档):
MindSpore python APIMindSpore Python APImindsporemindspore.common.initializermindspore.communicationmindspore.compressionmindspore.contextmindspore.datasetmindspore.dataset.configmindspore.dataset.textmindspore.dataset.transfORMsmindspore.dataset.visionmindspore.explainermindspore.mindrecordmindspore.nnmindspore.numpymindspore.nn.probabilitymindspore.opsmindspore.profilermindspore.trainMindArmour Python APImindarmourmindarmour.adv_robustness.attacksmindarmour.adv_robustness.defensesmindarmour.adv_robustness.detectorsmindarmour.adv_robustness.evaluationsmindarmour.fuzz_testingmindarmour.privacy.diff_privacymindarmour.privacy.evaluationmindarmour.privacy.sup_privacymindarmour.utilsMindSpore Hub Python APImindspore_hubMindSpore Serving Python APImindspore_servingMindQuantum Python APImindquantum
然后构造一个C++代码用于逐行读取这个文件,通过getline函数,将获取到的行字符串保存到strline中,并且每次读取一行都在屏幕上输出出来。由于这里使用的是while循环,因此采用index的方案设置了一个跳出循环的条件,只读取特定的行范围:
// iofile.cpp#include <iOStream>#include <fstream>#include <string>int main(){ using namespace std; string filename="mindspore.txt"; ifstream fin(filename.c_str()); int index = 0; string strline; while (getline(fin, strline) && index < 20) { cout << strline << endl; index ++; } fin.close(); cout << "Done!\n"; return 0;}
在读取完毕后,记得使用close()将文件关闭。上述代码的执行结果如下:
dechin@ubuntu2004:~/projects/gitlab/dechin/$ g++ iofile.cpp dechin@ubuntu2004:~/projects/gitlab/dechin/$ ./a.outMindSpore Python APIMindSpore Python APImindsporemindspore.common.initializermindspore.communicationmindspore.compressionmindspore.contextmindspore.datasetmindspore.dataset.configmindspore.dataset.textmindspore.dataset.transformsmindspore.dataset.visionmindspore.explainermindspore.mindrecordmindspore.nnmindspore.numpymindspore.nn.probabilitymindspore.opsmindspore.profilermindspore.trainDone!
这里我们使用的g++版本为9.3.0:
dechin@ubuntu2004:~/projects/gitlab/dechin/$ g++ --versiong++ (Ubuntu 9.3.0-17ubuntu1~20.04) 9.3.0Copyright (C) 2019 Free Software Foundation, Inc.This is free software; see the source for copying conditions. There is NOwarranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
因为上述案例读取的是前20行的内容,那么在linux下我们还可以通过head来查看前20行的文件内容:
dechin@ubuntu2004:~/projects/gitlab/dechin/$ head -n 20 mindspore.txt MindSpore Python APIMindSpore Python APImindsporemindspore.common.initializermindspore.communicationmindspore.compressionmindspore.contextmindspore.datasetmindspore.dataset.configmindspore.dataset.textmindspore.dataset.transformsmindspore.dataset.visionmindspore.explainermindspore.mindrecordmindspore.nnmindspore.numpymindspore.nn.probabilitymindspore.opsmindspore.profilermindspore.train
经过对比发现两个结果是一致的。
我们假象一个这样的测试案例,在上述的txt文本中,我们想把带有字符context的那一行标记出来,使其跟其他的行不一样。这时候就需要使用到C++的字符串匹配功能,其格式为string.find("context"),返回的是一个识别码,用于标记是否存在或者是存在的位置,如果字符不存在,则返回结果等价于string::npos。按照这个思路,我们定义一个布尔值,在检索过程中如果遇到context字符就输出1,否则输出0,具体的代码实现如下:
// iofile.cpp#include <iostream>#include <fstream>#include <string>int main(){ using namespace std; string filename="mindspore.txt"; ifstream fin(filename.c_str()); int index = 0; string strline; while (getline(fin, strline) && index < 20) { bool exists = strline.find("context") == string::npos; cout << strline << '\t' << !exists << endl; index ++; } fin.close(); cout << "Done!\n"; return 0;}
上述代码的执行结果如下所示:
dechin@ubuntu2004:~/projects/gitlab/dechin/$ g++ iofile.cpp && ./a.outMindSpore Python API 0MindSpore Python API 0mindspore 0mindspore.common.initializer 0mindspore.communication 0mindspore.compression 0mindspore.context 1mindspore.dataset 0mindspore.dataset.config 0mindspore.dataset.text 0mindspore.dataset.transforms 0mindspore.dataset.vision 0mindspore.explainer 0mindspore.mindrecord 0mindspore.nn 0mindspore.numpy 0mindspore.nn.probability 0mindspore.ops 0mindspore.profiler 0mindspore.train 0Done!
我们可以注意到,在含有context的那一行的行末输出了一个1,其他行的行末输出的都是0.
在python中我们常用的一个功能是导入time.time()来记录时间,然后计算两次时间之间的差值,就可以得到一个程序的精确运行时间。C++中有一个比较类似的用法是clock_t,这里为了方便测试,我们把上述用到的代码封装到一个reader函数内,然后在main函数中调用以及统计运行时间:
// iofile.cpp#include <iostream>#include <fstream>#include <string>#include <time.h>using namespace std;int reader(){ string filename="mindspore.txt"; ifstream fin(filename.c_str()); int index = 0; string strline; while (getline(fin, strline) && index < 20) { bool exists = strline.find("context") == string::npos; cout << strline << '\t' << !exists << endl; index ++; } fin.close(); cout << "Done!\n"; return 0;}int main(){ clock_t start, end; start = clock(); reader(); end = clock(); cout << "The time cost is: " << double(end-start)/CLOCKS_PER_SEC << "s" << endl;}
上述代码的执行结果如下所示:
dechin@ubuntu2004:~/projects/gitlab/dechin/$ g++ iofile.cpp && ./a.outMindSpore Python API 0MindSpore Python API 0mindspore 0mindspore.common.initializer 0mindspore.communication 0mindspore.compression 0mindspore.context 1mindspore.dataset 0mindspore.dataset.config 0mindspore.dataset.text 0mindspore.dataset.transforms 0mindspore.dataset.vision 0mindspore.explainer 0mindspore.mindrecord 0mindspore.nn 0mindspore.numpy 0mindspore.nn.probability 0mindspore.ops 0mindspore.profiler 0mindspore.train 0Done!The time cost is: 0.000245s
输出的时间表示这个函数运行时间共计0.2ms。
关于“c++如何实现文件逐行读取与字符匹配”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。
--结束END--
本文标题: c++如何实现文件逐行读取与字符匹配
本文链接: https://www.lsjlt.com/news/277361.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
下载Word文档到电脑,方便收藏和打印~
2024-03-01
2024-03-01
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0