python内置函数
1.试着向文件中写一句话
路径:“C:/Users/thinkpad/Desktop/demo.txt”
打开方式:写(‘w’)
# -*- encoding: UTF-8 -*-
fp = open("C:/Users/thinkpad/Desktop/demo.txt",'w')
fp.write('看,我学会了文件操作!')
fp.close() #关闭文件
你可以反复调用write()来写入文件,但是务必要调用f.close()来关闭文件。当我们写文件时,操作系统往往不会立刻把数据写入磁盘,而是放到内存缓存起来,空闲的时候再慢慢写入。只有调用close()方法时,操作系统才保证把没有写入的数据全部写入磁盘。忘记调用close()的后果是数据可能只写了一部分到磁盘,剩下的丢失了。所以,还是用with语句来得保险:
# -*- encoding: UTF-8 -*-
with open("C:/Users/thinkpad/Desktop/demo.txt",'w') as fp:
fp.write('看,我学会了文件操作!')
注意:
在这个示例中,如果你指定的路径下有没有’demo.txt’文件也没关系,python会自动创建这个文件再执行写的操作,具有这种特性的打开方式还有’w+’、‘a’、'a+‘等。其含义与操作与C语言中的相同。
提醒: 直接从系统中拷贝过来的路径名形式为 “D:\学习笔记\python文件操作.txt”
,要注意’'在python中为特殊字符(转义字符),所以直接这样用会报错,你需要改成
:“D:\学习笔记\python文件操作.txt” 或 “D:/学习笔记/python文件操作.txt”
2.把刚才的话读出来
# -*- encoding: UTF-8 -*-
with open("C:/Users/thinkpad/Desktop/demo.txt",'r') as fp:
str = fp.read()
print(str)
pickle模块
*在操作上,pickle模块和刚才介绍的内置函数并没有多大区别,可为什么还要引入pickle模块?主要优点有以下几点:
1.pickle提供了一个简单的持久化功能。可以将对象以文件的形式存放。
2.pickle模块只能在Python中使用,python中几乎所有的数据类型(列表,字典,集合,类等)都可以用pickle来序列化,且pickle序列化后的数据,可读性差,人一般无法识别,相对安全。
使用八股
头文件:import pickle
写
开:文件变量=open(“文件路径变量名”,“wb”)
存:pickle.dump(待写入变量,文件变量)
关:文件变量.close()
# -*- encoding: UTF-8 -*-
fp=open("save.dat","wb") #以二进制写入
pickle.dump(obj,fp)
save_file.close()
读
# -*- encoding: UTF-8 -*-
load_file=open("file_name.dat","rb")
obj=pickle.load(load_file)
load_file.close()
当然,我似乎更推荐你用上面介绍的with结构,简单且安全!
接下来我们来看一个例子:
# -*- encoding: UTF-8 -*-
a = ['老和尚','小和尚']
a.append(a) #添加递归
print(a)
print(a[2][0],a[2][1],a[2][2][0],a[2][2][1])
结果:
['老和尚', '小和尚', [...]]
老和尚 小和尚 老和尚 小和尚
这就是Python中列表的递归,无穷无尽的老和尚和小和尚,用第一种文件操作似乎无法保存这样特殊的对象,但是pickle模块就很好实现。代码如下:
# -*- encoding: UTF-8 -*-
a = ['老和尚','小和尚']
a.append(a) #添加递归
with open("C:/Users/thinkpad/Desktop/demo.pkl","wb") as fp:
pickle.dump(a,fp)
#如果你要把它读出来:
with open("C:/Users/thinkpad/Desktop/demo.pkl","rb") as fp:
a = pickle.load(fp)
上面可以引导你快速入门文件操作,想要了解更多请多查阅相关资料,有兴趣可以去了解一下OS模块。
一定要动手试一试