- C++读取文件:用文件流 ifstream,主要用到getline和stringstream
#include <iostream>
#include <vector>
#include <fstream>
#include <sstream>
#include <algorithm>
using namespace std;
int main() {
ifstream data("../data.txt"); //待读取文件的目录
vector<int> res;
string line;
while (getline(data, line)) {
stringstream ss; //输入流
ss << line; //向流中传值
if (!ss.eof()) {
int temp;
while (ss >> temp) //提取int数据
res.push_back(temp); //保存到vector
}
}
sort(res.begin(), res.end());
cout << res.back() << " " << res.front() << endl;
return 0;
}
或者使用freopen重定向标准输入
#include <iostream>
#include <vector>
#include <fstream>
#include <sstream>
#include <algorithm>
using namespace std;
int main() {
vector<int> res;
string line;
freopen("../data.txt", "r", stdin); //以“只读访问”方式,将标准输入重定向到 “data.txt” 文件
while (getline(cin, line)) {
stringstream ss; //输入流
ss << line; //向流中传值
if (!ss.eof()) {
int temp;
while (ss >> temp) //提取int数据
res.push_back(temp); //保存到vector
}
}
fclose(stdin);
sort(res.begin(), res.end());
cout << res.back() << " " << res.front() << endl;
return 0;
}
data.txt存放的数据
1 2 3 4 5 6 7 8 -9
13 15 17 19 21 -2 -4 -6 -8
12 14 16 18 20 -1 -5 -7 -9
结果输出最大值和最小值
21 -9
- 在对文本文件进行操作的时候,有read(),readline(),readlines()三种函数
read()一次性读取全部内容,放在一个大的字符串里面,即存在内存中。
file_object=open("test.txt")
try:
file_context=file_object.read()
finally:
file_object.close()
read()的利端:
· 方便、简单
· 一次性独读出文件放在一个大字符串中,速度最快
read()的弊端:
· 文件过大的时候,占用内存会过大
readline()逐行读取文件,返回的是一个list
with open(file) as f:
line=f.readline()
while line:
print(line)
line=f.readline()
readline()的利端:
· 占用内存小,逐行读取
readline()的弊端:
· 由于是逐行读取,速度比较慢
readlines() 一次性读取文本的所有内容,结果是一个list
with open(file) as f:
for line in f.readlines():
print(line)
这种方法读取的文本内容,每行文本末尾都会带一个’\n’换行符 (可以使用L.rstrip(’\n’)去掉换行符)
readlines()的利端:
· 一次性读取文本内容,速度比较快
readlines()的弊端:
· 随着文本的增大,占用内存会越来越多
还有一种比较快的逐行处理文本的方法,直接for循环文件对象
file_object = open('test.txt','rU')
try:
for line in file_object:
do_somthing_with(line) #line带"\n"
finally:
file_object.close()