C++实现文件逐行读取与字符匹配的示例详解
时间:2023-06-24 15:27:09来源:脚本之家
目录
技术背景C++读取文件C++字符串匹配C++运行时间统计总结概要

技术背景

用惯了python,对其他语言就比较的生疏。但是python很多时候在性能上比较受局限,这里尝试通过C++来实现一个文件IO的功能,看看是否能够比python的表现更好一些。关于python的类似功能的实现,可以参考这一篇博客。

C++读取文件

首先我们构造一个txt文件用于测试,比如以下这个名为mindspore.txt的文件(之所以取这个名字,是因为最近在研究mindspore,因此最方便拿到的数据就是mindspore的借口api文档):


【资料图】

MindSpore Python API
MindSpore Python API
mindspore
mindspore.common.initializer
mindspore.communication
mindspore.compression
mindspore.context
mindspore.dataset
mindspore.dataset.config
mindspore.dataset.text
mindspore.dataset.transforms
mindspore.dataset.vision
mindspore.explainer
mindspore.mindrecord
mindspore.nn
mindspore.numpy
mindspore.nn.probability
mindspore.ops
mindspore.profiler
mindspore.train
MindArmour Python API
mindarmour
mindarmour.adv_robustness.attacks
mindarmour.adv_robustness.defenses
mindarmour.adv_robustness.detectors
mindarmour.adv_robustness.evaluations
mindarmour.fuzz_testing
mindarmour.privacy.diff_privacy
mindarmour.privacy.evaluation
mindarmour.privacy.sup_privacy
mindarmour.utils
MindSpore Hub Python API
mindspore_hub
MindSpore Serving Python API
mindspore_serving
MindQuantum Python API
mindquantum

然后构造一个C++代码用于逐行读取这个文件,通过getline函数,将获取到的行字符串保存到strline中,并且每次读取一行都在屏幕上输出出来。由于这里使用的是while循环,因此采用index的方案设置了一个跳出循环的条件,只读取特定的行范围:

// iofile.cpp
#include 
#include 
#include 
 
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.out
MindSpore Python API
MindSpore Python API
mindspore
mindspore.common.initializer
mindspore.communication
mindspore.compression
mindspore.context
mindspore.dataset
mindspore.dataset.config
mindspore.dataset.text
mindspore.dataset.transforms
mindspore.dataset.vision
mindspore.explainer
mindspore.mindrecord
mindspore.nn
mindspore.numpy
mindspore.nn.probability
mindspore.ops
mindspore.profiler
mindspore.train
Done!

这里我们使用的g++版本为9.3.0:

dechin@ubuntu2004:~/projects/gitlab/dechin/$ g++ --version
g++ (Ubuntu 9.3.0-17ubuntu1~20.04) 9.3.0
Copyright (C) 2019 Free Software Foundation, Inc.
This is free software; see the source for copying conditions. There is NO
warranty; 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 API
MindSpore Python API
mindspore
mindspore.common.initializer
mindspore.communication
mindspore.compression
mindspore.context
mindspore.dataset
mindspore.dataset.config
mindspore.dataset.text
mindspore.dataset.transforms
mindspore.dataset.vision
mindspore.explainer
mindspore.mindrecord
mindspore.nn
mindspore.numpy
mindspore.nn.probability
mindspore.ops
mindspore.profiler
mindspore.train

经过对比发现两个结果是一致的。

C++字符串匹配

我们假象一个这样的测试案例,在上述的txt文本中,我们想把带有字符context的那一行标记出来,使其跟其他的行不一样。这时候就需要使用到C++的字符串匹配功能,其格式为string.find("context"),返回的是一个识别码,用于标记是否存在或者是存在的位置,如果字符不存在,则返回结果等价于string::npos。按照这个思路,我们定义一个布尔值,在检索过程中如果遇到context字符就输出1,否则输出0,具体的代码实现如下:

// iofile.cpp
#include 
#include 
#include 
 
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.out
MindSpore Python API 0
MindSpore Python API 0
mindspore 0
mindspore.common.initializer 0
mindspore.communication 0
mindspore.compression 0
mindspore.context 1
mindspore.dataset 0
mindspore.dataset.config 0
mindspore.dataset.text 0
mindspore.dataset.transforms 0
mindspore.dataset.vision 0
mindspore.explainer 0
mindspore.mindrecord 0
mindspore.nn 0
mindspore.numpy 0
mindspore.nn.probability 0
mindspore.ops 0
mindspore.profiler 0
mindspore.train 0
Done!

我们可以注意到,在含有context的那一行的行末输出了一个1,其他行的行末输出的都是0.

C++运行时间统计

在python中我们常用的一个功能是导入time.time()来记录时间,然后计算两次时间之间的差值,就可以得到一个程序的精确运行时间。C++中有一个比较类似的用法是clock_t,这里为了方便测试,我们把上述用到的代码封装到一个reader函数内,然后在main函数中调用以及统计运行时间:

// iofile.cpp
#include 
#include 
#include 
#include 
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.out
MindSpore Python API 0
MindSpore Python API 0
mindspore 0
mindspore.common.initializer 0
mindspore.communication 0
mindspore.compression 0
mindspore.context 1
mindspore.dataset 0
mindspore.dataset.config 0
mindspore.dataset.text 0
mindspore.dataset.transforms 0
mindspore.dataset.vision 0
mindspore.explainer 0
mindspore.mindrecord 0
mindspore.nn 0
mindspore.numpy 0
mindspore.nn.probability 0
mindspore.ops 0
mindspore.profiler 0
mindspore.train 0
Done!
The time cost is: 0.000245s

输出的时间表示这个函数运行时间共计0.2ms。

总结概要

本文简单的介绍了C++中的三种基础操作:逐行读取文件内容、字符串匹配以及运行时间的统计,并且通过一个简单的范例来实现了这三种基本的功能。相比于python而言,C++的代码编写量肯定要多一些,但是考虑到C++可能带来的效率增益,我们也应当了解其基本的用法以及功能实现。

以上就是C++实现文件逐行读取与字符匹配的示例详解的详细内容,更多关于C++文件逐行读取与字符匹配的资料请关注脚本之家其它相关文章!

标签:

生活指南
  • 世界即时看!除湿气的小妙方_除湿气最好的方法有哪些

    1、食疗祛湿食疗可以有效去除湿气,且方便又实用。2、建议在日常的饮食

  • 巨头3M因污染环境赔740亿元:部分产品极难降解,进血液会长久积存 天天时快讯

    化工巨头3M公司周四盘后宣布,同意支付最高可达125亿美元的和解金,以

  • 浙江临安:乡贤人才齐聚力 共富菜园再升级

    6月22日,又是一年端午节。2023“潮创浙西·聚力共富”龙井峡漂流狂欢

  • 焦点讯息:揭阳打造“心适小屋”筑牢市民心灵“防护墙”

    记者日前从揭阳市政府获悉,一年多来,揭阳市委政法委通过积极探索,结

  • 【整活向】第五人格X赛尔号:新监管者——“团长”_天天百事通

    当人们等待着黑暗散去之时、当人们期盼着美好未来之时,佩德藏在光明无

  • 世界微速讯:超卓航科(688237.SH):497.43万股限售股7月3日起上市流通

    格隆汇6月21日丨超卓航科(688237 SH)公布,公司本次上市流通的限售股东

  • 威孚高科(000581.SZ)拟10股派1元 于6月30日分红-世界热议

    智通财经讯,威孚高科(000581 SZ)公告,公司2022年年度权益分派拟:向

  • 环球新动态:四代篮球人见证“村BA”发展变迁

    新华社贵阳6月20日电(记者蒋成)“我的身体还硬朗,如果可以,我还想

  • 龙虎风云会的武功排名 天天报道

    1、第一名:横推八百无对手轩辕重出武圣人于和,书中的武林第一把交椅

  • 每日热议!吴淞创新城建设提速,百年纺织厂蝶变“时尚+科技”产业高地

      加快南北转型,是振兴上海老工业基地、构建城市发展新格局的战略之

  • 2023广州黄埔区汽车补贴多少钱一辆?

    为全面落实省、市强经济、促消费政策措施,进一步激发黄埔区夜间经济全

  • 日本强行排污入海,后果有多可怕?-全球最资讯

    国内起义,国外抗议,不管这里里外外的的反对声有多大,终究还是没拦住

  • 热文:“去美元化”或已不可逆转

    徐秀军(中国社会科学院世界经济与政治研究所研究员)  当前,全球“

  • 黄金走势分析最新消息(2023年6月16日)-每日信息

    基本消息面周五(6月16日),现货黄金短线突然快速上升,金价刚刚突破196

  • 印尼羽毛球公开赛混双1/4决赛:冯彦哲/黄东萍逆转击败德沙组合,挺进半决赛!_世界动态

    本场比赛,冯彦哲 黄东萍逆转战胜德差波 沙西丽,晋级四强,让人看得热

  • 推进高素质行业人才培养,湖南城建职业技术学院外聘专家48名 环球通讯

    6月14日下午,湖南城建职业技术学院举行校外专家聘任仪式,聘请了48名

  • 民生
    • 世界观速讯丨儋州二手房投资讲解,普天豪苑二手房能不能升值?

    • AI代写论文,该不该管?-环球报资讯

    • 又一家大公司要加入特斯拉超充站了? 快资讯

    • 广元市青川县市场监管局开展首期青年理论小组学习活动|每日看点