2021-12-22 Python-17

文件操作

文件读取

文件读取到内存中时,可以通过一次性读取文件的全部内容,也可以每次一行方式逐步读取。
1.读取整个文件
假设在当前文件夹中存在一个 pi.txt 的文件,可以通过 open() 函数将文件打开,通过read函数读取文件。

with open('pi.txt') as pi_file:
    content=pi_file.read()
content.rstrip()

open 函数读取了文件,并将其储存在变量 pi_file 中。关键词with在不再需要访问文件后将其文件关闭。也可以使用 open 和 close 函数去执行,但是如果 close 前面的语句未正常运行,导致文件没有正常关闭,可能会对文件造成损害。
read 方法将文件读取得内容储存到 content 变量中,再将变量输出。

  1. 按行读取文件
with open('pi.txt') as file_name:
    for line in file_name:
        print(line)
#输出的结果每一行末尾都多了一行,因为print函数会自动在输出的末尾加换行符,而文件中每一行末尾也有换行符,所以就多了一个空行,可以用以下的语句替换
#print(line.rstrip()) 将右侧的空格除去

按照上述方法逐行读取时,只能在 with 内访问文件,因为with运行结束后,文件就关闭了,所以无法在 with 外访问。
如果想要在with语句结束后还对文件进行操作,可以用 readlines 函数读取文件的每一行,作为变量储存在列表中。

with open('pi.txt') as file_name:
    lines=file_name.readlines()
lines
''' ['3.14159  26535 89793  23846 26433  83279 50288  41971\n',
 ' 69399  37510 58209  74944 59230  78164 06286 \n',
 '  20899 86280  34825 34211  70679'] '''
for line in lines:
    print(line.rstrip())

上述将每一行的内容储存在名为 lines 的列表中,每个元素代表文件中一行的内容。
因为变量在文件关闭后仍存在,所以可以在 with 代码外使用。

后续可以对文件内容进行操作


pi.txt文件内容
#假设pi.txt中的文件内容如上图所示,输出 在一行的数字,并且中间无空格。类似3.1415926...
import re
with open('pi.txt') as file_name:
    lines=file_name.readlines()
#和上面的操作一样,将文件按行读取
string=''
for line in lines:
    string=string+line.strip()
string=re.sub('\s+','',string)
string
#'3.1415926535897932384626433832795028841971693993751058209749445923078164062862089986280348253421170679'
#注意在python读取文件的时候,默认把所有的文本读取为字符串的形式

3.文件路径
假设当前运行目录在spyder workdirectory下,text时该目录下的一个子文件夹,text文件中pi.txt的文件。可以通过指定路径读取文件。

path=r'D:\spyder workdirectory\\text\pi.txt'
#path='D:\\spyder workdirectory\\text\\pi.txt'
with open(path) as file_object:
    content_1=file_object.read()
content_1.rstrip()
#windows中的路径用 \ 或者 \\,但是再编译的时候\会被当作转义字符,可以通过加 r' ' 的方式或者 \\ 的方式。上面的方法是采用了绝对路径,因为text目录包括在spyder workdirectory目录下,所以也可以采用相对路径
#path='text\\pi.txt'

你可能感兴趣的:(2021-12-22 Python-17)