1、文本文件读写
- 方式一
直接读入
file1 = open("test.txt")
file2 = open("output.txt","w")
while True:
line = file1.readline()
#这里可以进行逻辑处理
file2.write('"'+line[:s]+'"'+",")
if not line:
break
#记住文件处理完,关闭是个好习惯
file1.close()
file2.close()
#read():将文本文件所有行读到一个字符串中。
#readline():是一行一行的读
#readlines():是将文本文件中所有行读到一个list中,文本文件每一行是list的一个元 素。优点:readline()可以在读行过程中跳过特定行。
- 方式二
文件迭代器
file2 = open("output.txt","w")
for line in open("test.txt"):
#这里可以进行逻辑处理
file2.write('"'+line[:s]+'"'+",")
- 方式三
#打开文件
#用with..open自带关闭文本的功能
with open('somefile.txt', 'r') as f:
data = f.read()
# loop整个文档
with open('somefile.txt', 'r') as f:
for line in f:
# 处理每一行
# 写入文本
with open('somefile.txt', 'w') as f:
f.write(text1)
f.write(text2)
...
# 把要打印的line写入文件中
with open('somefile.txt', 'w') as f:
print(line1, file=f)
print(line2, file=f)
2、二进制文件读写
Python默认读取的都是文本文件。要是想要读取二进制文件,需要把’r’改成’rb’.
f = open('EDC.jpg', 'rb')
print(f.read())
# 输出 '\xff\xd8\xff\xe1\x00\x18Exif\x00\x00...' # 十六进制表示的字节
简单说就是,任何非标准的文本文件(对于Py2来说,标准是ASCII,对于Py3来说,标准是unicode),你就需要用二进制读入这个文件,然后再用 .decode(‘…’)的方法来解码这个二进制文件:
3、文件操作
创建文件
# 当前目录的绝对路径 输出 H:\pythonWorkspace\pycharm
print(os.path.abspath('.'))
# path 为要创建的pictures目录的绝对路径
path = os.path.join(os.path.abspath('.'), 'Pictures')
# 在当前路径下创建一个新目录(文件已经存在时,无法创建)
os.mkdir(path)
# 删除一个文件夹
os.rmdir(path)
拆分路径
# 对路径进行拆分,拆分完分为两部分,最后一部分总是最后级别的目录或文件名
# 输出 元组('H:/pythonWorkspace/pycharm', 'a.jpg')
os.path.split('H:/pythonWorkspace/pycharm/a.jpg')
# 最后一部分是文件扩展名
# 输出元组('H:/pythonWorkspace/pycharm/a', '.jpg')
os.path.splitext('H:/pythonWorkspace/pycharm/a.jpg')
文件重命名和删除
# 文件重命名
os.rename('JAV-001.avi', '学习资料')
# 文件删除
os.remove('学习资料')
文件复制(使用第三方库 shutil)
import shutil
# 将文件src复制到文件dst
shutil.copyfile(src, dst)
案例
# 列出当前目录下的所有文件夹
list = [x for x in os.listdir('.') if os.path.isdir(x)]
# 列出当前目录下的特定文件 以后缀名为.py的文件
list = [x for x in os.listdir('.') if os.path.isfile(x) and os.path.splitext(x)[1] == '.py']