C/C++——打开文件读取数据的各种方式「建议收藏」

C/C++——打开文件读取数据的各种方式「建议收藏」打开文件在fstream类中,成员函数open()实现打开文件的操作,从而将数据流和文件进行关联,通过ofstream,ifstream,fstream对象进行对文件的读写操作函数:open()voidopen(constchar*filename,ios_base::openmodemode=ios_base::in|ios_base::ou

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

打开文件

在fstream类中,成员函数open()实现打开文件的操作,从而将数据流和文件进行关联,通过ofstream,ifstream,fstream对象进行对文件的读写操作
函数:open()

void open ( const char * filename,  
            ios_base::openmode mode = ios_base::in | ios_base::out );  

void open(const wchar_t *_Filename,  
        ios_base::openmode mode= ios_base::in | ios_base::out,  
        int prot = ios_base::_Openprot); 

     参数: filename    操作文件名
           mode        打开文件的方式
           prot        打开文件的属性     //基本很少用到,在查看资料时,发现有两种方式

例子:

ofstream out;  
out.open("data.txt", ios::in|ios::out|ios::binary) 

fstream 流方法读数据

data.txt文件如下
这里写图片描述
1.读取方式: 逐词读取, 读词之间用空格区分

void readdatafromfileWBW()
{
    ifstream fin("data.txt");
    string s;
    while (fin >> s)
    {
        cout << s << " ";//空格是为了避免数据都连在一块儿
    }
    cout << endl;
}

程序结果:(每个数都要读取一次)
这里写图片描述

2.读取方式: 逐行读取, 将行读入字符数组, 行之间用回车换行区分

void readdatafromfileLBL()
{
    ifstream fin("data.txt");
    const int LINE_LENGTH = 100;
    char str[LINE_LENGTH];
    while (fin.getline(str, LINE_LENGTH))
    {
        cout << "Read from file: " << str << endl;//要输出4次
    }
}

程序结果:
这里写图片描述

3.读取方式: 逐行读取, 将行读入字符串, 行之间用回车换行区分

void readdatafromfileLBL()
{
    ifstream fin("data.txt");
    string s;
    while (getline(fin, s))
    {
        cout << "Read from file: " << s << endl;//读取4次(4行)
    }
}

程序结果:
这里写图片描述

4.读取时检测

void readfile(string filename){
    ifstream fin(filename);
    string s;
    if (!fin)//检测文件输入是否正常
    {
        cout << "文件不能打开" << endl;
    }
    else{
        while (fin >> s){
            cout << s << ' ';
        }
        cout << endl;
    }
    fin.close();
}

C语言打开文件读取数据

C语言中要打开一个文件,需要调用fopen函数。
一、函数名:fopen
二、头文件:stdio.h
三、函数声明:
FILE * fopen(const char * path,const char * mode);
四、函数参数:
参数path字符串包含欲打开的文件路径及文件名,可以是相对路径,也可以是绝对路径。
参数mode字符串则代表着流形态。常见的mode形式有如下几种:
r 以只读方式打开文件,该文件必须存在。
r+ 以可读写方式打开文件,该文件必须存在。
rb+ 读写打开一个二进制文件,允许读写数据,文件必须存在。
w 打开只写文件,若文件存在则文件长度清为0,即该文件内容会消失。若文件不存在则建立该文件。
w+ 打开可读写文件,若文件存在则文件长度清为零,即该文件内容会消失。若文件不存在则建立该文件。
a 以附加的方式打开只写文件。若文件不存在,则会建立该文件,如果文件存在,写入的数据会被加到文件尾,即文件原先的内容会被保留。(EOF符保留)
a+ 以附加方式打开可读写的文件。若文件不存在,则会建立该文件,如果文件存在,写入的数据会被加到文件尾后,即文件原先的内容会被保留。 (原来的EOF符不保留)
wb 只写打开或新建一个二进制文件;只允许写数据。
wb+ 读写打开或建立一个二进制文件,允许读和写。
ab+ 读写打开一个二进制文件,允许读或在文件末追加数据。
五、返回值:
如果操作成功,会返回一个非空的FILE*指针,该指针用于后续对文件的操作,如读、写、关闭等。
如失败返回NULL。

在C语言中提供了多种文件读写的函数:
·字符读写函数 :fgetc和fputc
·字符串读写函数:fgets和fputs
·数据块读写函数:freed和fwrite
·格式化读写函数:fscanf和fprinf

读取文件
程序1:
fgetc函数的功能是从指定的文件中读一个字符,函数调用的形式为:字符变量=fgetc(文件指针);例如:ch=fgetc(fp);其意义是从打开的文件fp中读取一个字符并送入ch中。

#include <stdio.h>

int main()
{
    FILE *fp;
    char ch;
    if ((fp = fopen("data.txt", "r") )== NULL){
        printf("Cannot open file\n");
    }
    else{
        ch = fgetc(fp);
        while (ch != EOF){
            putchar(ch);
            ch = fgetc(fp);
        }
    }
    fclose(fp);
    return 0;
}

程序2:
fgets(str,n,fp);的意义是从fp所指的文件中读出n-1个字符送入字符数组str中。

#include <stdio.h>

int main()
{
    FILE *fp;
    char ch[100];
    if ((fp = fopen("data.txt", "r") )== NULL){
        printf("Cannot open file\n");
    }
    else{
        while (fgets(ch, 100, fp)){
            printf("%s",ch);
        }
    }
    printf("\n");
    fclose(fp);
    return 0;
}

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/182223.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Linux smart_linux安装smartctl

    Linux smart_linux安装smartctlSmartmontools是一种硬盘检测工具,通过控制和管理硬盘的SMART(SelfMonitoringAnalysisandReportingTechnology),自动检测分析及报告技术)技术来实现的,SMART技术可以对硬盘的磁头单元、盘片电机驱动系统、硬盘内部电路以及盘片表面介质材料等进行监测,当SMART监测并分析出硬盘可能出现问题时会及时向用户报警以避免计算机数据受损失。SMART技术必须在主板支持的前提下才能发生作用,而且SMART技术也不能保证能预报所有可能发生的硬盘故障。

    2022年10月8日
    0
  • 图 欧拉回路

    图 欧拉回路欧拉道路 即一笔画 从图的一个结点出发走出一条道路 每条边恰好经过一次欧拉回路 从任意点出发 最终回到该点的欧拉道路 1 前提 忽略边的方向后 图是连通的 dfs bfs 并查集 2 条件 有向图 最多只有两个点的入度不等于出度 且相差的绝对值是 1 无向图 最多只有两个点的度是奇数 3 若有特殊点 则特殊的点为起点 若无任意点都可为起点寻找路径方法 DFS 构造一般的版本 void

    2025年6月13日
    0
  • idea2019最新可用激活码_通用破解码

    idea2019最新可用激活码_通用破解码,https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月16日
    1.0K
  • 一致性哈希算法原理详解

    一致性哈希算法原理详解(1)一致性哈希算法将整个哈希值空间按照顺时针方向组织成一个虚拟的圆环,称为Hash环;(2)接着将各个服务器使用Hash函数进行哈希,具体可以选择服务器的IP或主机名作为关键字进行哈希,从而确定每台机器在哈希环上的位置;(3)最后使用算法定位数据访问到相应服务器:将数据key使用相同的函数Hash计算出哈希值,并确定此数据在环上的位置,从此位置沿环顺时针寻找,第一台遇到的服务器就是其应该定位到的服务器

    2022年7月27日
    3
  • SQL Developer_Netbank

    SQL Developer_NetbankOracle .Net Develoer

    2022年4月22日
    46
  • 重启MySQL服务(怎么重启mysql服务)

    重启MySQL服务(怎么重启mysql服务)一、MYSQL服务我的电脑——(右键)管理——服务与应用程序——服务——MYSQL——开启(停止、重启动)二、命令行方式Windows1.点击“开始”->“运行”(快捷键Win+R)。2.启动:输入netstopmysql3.停止:输入netstartmysql提示*RedhatLinux也支持servicecommand,启动:#servicemysqldstar…

    2022年4月18日
    254

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号