Python基础 - 文件和流

简介: Python基础 - 文件和流

1、打开文件


open(name[,mode[,buffering]])


open函数使用一个文件名作为其唯一的一个强制参数,然后返回一个文件对象。模式(mode)和缓冲区(buffering)是可选的。


模式:


   'r'  读模式


  'w'   写模式


  'a'   追加模式


   'b'    二进制模式,添加到其他模式中使用


   '+'   读/写模式,添加到其他模式中使用


'+'参数可以用来任何模式后,指明读和写都是可以的。'b'模式改变处理文件的方法。


二进制模式和文本模式的区别:在使用二进制模式时,python会原样地给出文件中的内容,但文本模式下则不一定。python会在文本模式下做一些转换:当在windows下用文本模式读取文件时,python会将\r\n转换成\n,相反,当在windows下用文本模式写文件时,会把\n转换成\r\n。


缓冲:


 如果参数为0,I/O就是无缓冲,所有的读写操作直接针对硬盘。如果是1,I/O就用内存来代替硬盘,是程序更快,使用flush或close时才把内容写入硬盘。


2、读和写


f = open()


f.read(n) 读取n个字节


f.write(str)


f.close()


3、管式输出


使用管道可以在一个命令的后面续写其他多个命令,管道符号将一个命令的标准输出和下一个命令的标准输入连在一起。


$ cat test.txt | python somescript.py


文件流随机访问函数seek(offset),把当前位置移动到offset定义的位置。


4、读写行


file.readline(n)当n为空是,读取单独一行,并读取文件换行符,当n为非负值时读取文件的前n个字符。


file.readlines()读取一个文件中的所有行,并以列表的返回。


file.writeline()没有此函数。


file.wirtelines()将一个字符串列表写入到字符串文件中。


5、如果想确保文件被关闭了,那么应该使用try/finally语句,并且在finally字句中调用close()方法。


try:


 file = open()


 #操作文件


finaly:


 file.close()


with语句可以打开文件并将其赋值到变量上:


with open() as somefile:
    do_someting(somefile)

6、对文件内容进行迭代


6.1 按字节处理,在循环里做如下操作


f.read(1)


6.2 按行处理,在循环里做如下操作


f.readline()


6.3 处理整个文件


f.read() 将文件当做一个字符串来获取


f.readlines() 将文件读入到一个字符串列表


7、使用fileinput实现懒惰行迭代


懒惰行迭代的原因:在读取非常大的文件,readlines会占用太多的内存,而懒惰行迭代只是读取文件中实际需要的部分。


import fileinput
for line in fileinput.input(filename):
  process(line)

8、文件迭代器


文件对象是可以按照行进行迭代的。


f = open(filename)
for line in f:
  process(line)
f.close()


可以对文件迭代器执行和普通迭代器相同的操作:list(open(filename))


相关文章
|
13天前
|
Python
python文件读写操作的三大基本步骤
python文件读写操作的三大基本步骤
31 0
|
1天前
|
前端开发 JavaScript Python
使用Python读取本地行情csv文件,做出web网页画出K线图实现案例
【5月更文挑战第4天】使用Python绘制K线图的步骤:1) 安装pandas, matplotlib和Flask;2) 用pandas读取CSV文件并处理数据;3) 创建Flask应用,渲染包含K线图数据的HTML;4) 编写HTML,使用ECharts库绘制K线图。
13 0
|
7天前
|
Linux iOS开发 MacOS
pyinstaller---Python代码的打包神器,一键将python代码打包成exe可执行文件
pyinstaller---Python代码的打包神器,一键将python代码打包成exe可执行文件
|
7天前
|
NoSQL Python
在Python中,我们可以使用许多库来处理Excel文件
Python处理Excel常用pandas和openpyxl库。pandas的`read_excel`用于读取文件,`to_excel`写入;示例展示了数据框操作。openpyxl则用于处理复杂情况,如多工作表,`load_workbook`加载文件,`iter_rows`读取数据,`Workbook`创建新文件,写入单元格数据后保存。
14 1
|
8天前
【Python21天学习挑战赛】文件读写操作
【Python21天学习挑战赛】文件读写操作
|
10天前
|
数据采集 存储 人工智能
Python采集数据保存CSV文件内容乱码解决
Python采集数据保存CSV文件内容乱码解决
25 1
|
11天前
|
JSON JavaScript 数据格式
python遍历目录文件_结合vue获取所有的html文件并且展示
python遍历目录文件_结合vue获取所有的html文件并且展示
4 0
|
12天前
|
存储 安全 Python
Python从入门到精通:2.2.2异常处理与文件操作:文件的打开、读取、写入和关闭操作。
Python从入门到精通:2.2.2异常处理与文件操作:文件的打开、读取、写入和关闭操作。
|
13天前
|
数据安全/隐私保护 Python
Python 中删除文件夹下文件的方法详解
本文探讨了Python删除文件夹中特定文件的三种方法。使用os模块简单直接,适合基础操作,但不支持递归删除;shutil库能递归删除整个文件夹,需谨慎使用;glob模块则按文件名模式匹配并删除,灵活性高但范围受限。根据需求和安全性考虑选择合适的方法。
3 0
|
14天前
|
Python
python html(文件/url/html字符串)转pdf
python html(文件/url/html字符串)转pdf
9 0