前篇的意思就是说......我还没有成为python王者(想写大神居然通不过),只是刚刚入了个门。总是在艳羡人家玩爬虫啊,办公自动化啊,还用python玩玩股票啊,看起来都牛逼哄哄。我也不愿再做小菜鸟了,我也要发家致富!第一步就是把我每天学到的货色记录下来,加深点印象。有没有骚年跟我一起冲!!!好了好了,我先冲。(如果小白看到了,对我所写的务必持狐疑态度;如果大神偶然瞄到了,我写错了麻烦纠正下哈!)
文件操作
1. 根本步骤
用几句简略的代码形容下步骤:
# 1. 创立文件对象,关上f = open('test.txt', 'w')# 2. 写入内容f.write('test')# 3. 敞开文件对象f.close()
留神:文件对象须要敞开,否则会始终占用内存。
2. 拜访模式
模式 | 形容 |
---|---|
r | 以只读形式关上文件。文件的指针将会放在文件的结尾。这是默认模式。 |
rb | 以二进制格局关上一个文件用于只读。文件指针将会放在文件的结尾。这是默认模式。 |
r+ | 关上一个文件用于读写。文件指针将会放在文件的结尾。 |
rb+ | 以二进制格局关上一个文件用于读写。文件指针将会放在文件的结尾。 |
w | 关上一个文件只用于写入。如果该文件已存在则关上文件,并从结尾开始编辑,即原有内容会被删除。如果该文件不存在,创立新文件。 |
wb | 以二进制格局关上一个文件只用于写入。如果该文件已存在则关上文件,并从结尾开始编辑,即原有内容会被删除。如果该文件不存在,创立新文件。 |
w+ | 关上一个文件用于读写。如果该文件已存在则关上文件,并从结尾开始编辑,即原有内容会被删除。如果该文件不存在,创立新文件。 |
wb+ | 以二进制格局关上一个文件用于读写。如果该文件已存在则关上文件,并从结尾开始编辑,即原有内容会被删除。如果该文件不存在,创立新文件。 |
a | 关上一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创立新文件进行写入。 |
ab | 以二进制格局关上一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创立新文件进行写入。 |
a+ | 关上一个文件用于读写。如果该文件已存在,文件指针将会放在文件的结尾。文件关上时会是追加模式。如果该文件不存在,创立新文件用于读写。 |
ab+ | 以二进制格局关上一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。如果该文件不存在,创立新文件用于读写。 |
这里介绍几个主拜访模式:
- r 只读,不反对写入,如果文件不存在会报错;
- w 只写,文件不存在会新建文件;写入内容会笼罩原来内容;
- a 追加,文件不存在会新建文件;写入内容追加至原来内容后;
如果没有拜访模式,默认为‘r’。
r+,w+,a+的区别:
三种模式都是可读可写,而r+听从r的属性,如果文件不存在就会报错;r+和w+的文件指针在文件的结尾,而a+的文件指针在文件的结尾,因而应用a+是无奈通过.read()间接读取的;而应用w+会应用新内容去笼罩,应用.read()也是无奈间接读取的。
3. 文件对象办法
3.1 读
3.1.1 read()
对象.read(num)
num示意从文件中读取数据的字节长度,没有num就是读取全副;能够应用print()打印输出。
3.2 readlines()
依照行的形式一次性读取整个内容,并返回一个列表(记得换行符噢);
3.3 readline()
一次读取一行内容;
f = open('test.txt')content = f.readline()print(f'第一行:{content}')content = f.readline()print(f'第二行:{content}')f.close()
3.4 seek()
作用:挪动文件指针(就能够解决下面说的“无奈间接读取数据”啦!)文件对象.seek(偏移量, 起始地位)
起始地位:
- 0:文件结尾
- 1:以后地位
- 2:文件结尾
f = open('test.txt', 'w+')f.write('aaa')f.seek(0)print(f.read())f.close()
如果不应用seek的话,在从新笼罩了test.txt之后,写入内容也是无奈间接读取的,因为此时指针在‘aaa’的前面,而seek(0),即seek(0,0),挪动了指针的地位到结尾,那么此时就能够通过read()读取啦!
4. 文件备份
算是一个常识利用吧
先温习一个字符串里的函数,用于寻找最初一次呈现查找字符串的地位:string.rfind(str, beg=0,end=len(string))
- str: 查找的字符串
- beg: 开始查找的地位,默认为0
- end: 完结查找地位,默认为str的长度
old_name = input("输出备份文件名:")# 找到最初一次呈现该字符串的地位并返回index = old_name.rfind('.')if index > 0: # 这里是避免文件名的不规则性 # 记录后缀名 postfix = old_name[index:]# 创立备份文件名new_name = old_name[:index]+'_bak'+postfix# 只读关上源文件,只写关上备份文件(新建)old_f = open(old_name, 'rb') # 用二进制读写new_f = open(new_name, 'wb')# 写入content = old_f.read()new_f.write(content)# 敞开文件old_f.close()new_f.close()
在课程中,写入的时候老师应用了old_f.read(1024)并进行while True的循环,直到内容为空才break退出循环,起因是不是.read()有可能会读取不到所有数据?
5. os模块
import os
- 文件重命名
os.rename()
- 删除文件
os.remove()
- 创立文件夹
os.mkdir()
- 删除文件夹
os.rmdir()
- 获取当前目录
os.getcwd()
- 扭转默认目录
os.chdir()
- 获取目录列表
os.listdir()
那么,来个利用案例坚固一下,批量重命名当前目录下的文件:
import os# 获取当前目录curr_dir = os.getcwd()print(curr_dir)# 将当前目录下的所有文件重命名为secret_...for file in os.listdir(curr_dir): os.rename(file, 'secret_'+file)
6. 集体补充
课程里没有with open(...) as f:
的用法,还好之前学到过,这样的写法最大区别就是不必敞开文件了,程序会主动敞开。写法差不多,当然写法还是越简便越好!