Home >Backend Development >Python Tutorial >Detailed explanation of reading and writing files in Python
This article mainly introduces the detailed explanation about reading and writing files in Python. The editor thinks it is quite good. Now I will share it with you and make it for everyone. refer to. Let’s follow the editor and take a look.
Read data from the file
Read the entire File
Assume here that there is a text file named 'pi_digits.txt' in the current directory. The data in it is as follows:
3.1415926535 8979323846 2643383279
with open('pi_digits.txt') as f: # 默认模式为‘r’,只读模式 contents = f.read() # 读取文件全部内容 print contents # 输出时在最后会多出一行(read()函数到达文件末会返回一个空字符,显示出空字符就是一个空行) print '------------' print contents.rstrip() # rstrip()函数用于删除字符串末的空白
3.1415926535 8979323846 2643383279 ------------ 3.1415926535 8979323846 2643383279
The data can be read line by line through a loop:
with open('pi_digits.txt') as f: for line1 in f: print line1 # 每行末尾会有一个换行符 print '------------' for line2 in f: print line2.rstrip() # 此时文件已经读完,line2指向文本末尾,因此不会有输出
3.1415926535 8979323846 2643383279 ------------
When reading a file, it is equivalent to having a pointer recording the reading position. Wherever the data is read, the pointer points. Edge, when continuing to read data, it will continue to read from this position, so the output in the second loop in the above code is empty. Modify the above code slightly as follows:
with open('pi_digits.txt') as f: for line1 in f: print line1 print '------------' with open('pi_digits.txt') as f: # 需要重新打开文本进行读取 for line2 in f: print line2.rstrip() # 删除字符串末尾的空白
3.1415926535 8979323846 2643383279 ------------ 3.1415926535 8979323846 2643383279
The above code is equivalent to closing the file after reading it for the first time and reopening it for reading. You can also use the readline() function to read data line by line, as follows:
with open('pi_digits.txt') as f: # readline()每一次读取一行数据,并指向该行末尾 line1 = f.readline() # 读取第一行数据(此时已经指向第一行末尾) line2 = f.readline() # 从上一次读取末尾开始读取(第二行) print line1.rstrip() print line2.rstrip()
3.1415926535 8979323846
Sometimes we want to read all the data at once and store it separately to facilitate subsequent operations. Of course, this can be achieved using the above loop. , but python provides a simpler method readlines():
with open('pi_digits.txt') as f: lines = f.readlines() # 读取文本中所有内容,并保存在一个列表中,列表中每一个元素对应一行数据 print lines # 每一行数据都包含了换行符 print '------------' for line in lines: print line.rstrip() print '------------ 'pi_str = '' # 初始化为空字符 for line in lines: pi_str += line.rstrip() #字符串连接 print pi_str
['3.1415926535\n', '8979323846\n', '2643383279\n'] ------------ 3.1415926535 8979323846 2643383279 ------------ 3.141592653589793238462643383279
There are several different modes for writing data, the most commonly used ones are w', 'a', Respectively means erasing the original data and then writing it and writing the data to the original data:
filename = 'write_data.txt' with open(filename,'w') as f: # 如果filename不存在会自动创建, 'w'表示写数据,写之前会清空文件中的原有数据! f.write("I am Meringue.\n") f.write("I am now studying in NJTECH.\n")
At this time, a text file of 'write_data.txt' will be created under the current path and written to the file. The data is as follows:
I am Meringue. I am now studying in NJTECH.
Continue to add new data to the file:
with open(filename,'a') as f: # 'a'表示append,即在原来文件内容后继续写数据(不清楚原有数据) f.write("I major in Machine learning and Computer vision.\n")
The content of the file at this time is:
I am Meringue. I am now studying in NJTECH. I major in Machine learning and Computer vision.
The above is the detailed content of Detailed explanation of reading and writing files in Python. For more information, please follow other related articles on the PHP Chinese website!