1.文件:存储在外部介质上的数据或信息集合;有序的数据序列、
2.文本显示:计算机显示功能的基本问题
3.编码:信息从一种形式或格式转化为另一种形式的过程。
常用的编码:
(1)ASCII码是标准化字符集 7个二进制位编码 表示128个字符
(2)Unicode 跨语言、跨平台 统一且唯一的二进制编码 每个字符两个字节长
(3)UTF-8编码 可变长度的Unicode
4.python中字符串类型未编码
编码encode()
解码decode()
5.打开文件:建立磁盘上的文件与程序中的对象相关联
open()
<variable> = open(<name>,<mode>)
<name>磁盘文件名
<mode>打开模式
(1)r 只读,如果文件不存在,则输入错误
(2)w 只写,如果文件不存在,则自动创建文件
(3)a 附加到文件末尾
(4)rb 只读二进制文件,如果文件不存在,则输出错误
(5)wb只写二进制文件,如果文件不存在,则自动创建文件
(6)ab 附加到二进制文件末尾
(7)r+ 读写
例如:infile = open(“number.dat”,’r’)
文件操作:读取、写入、定位
文件的读取
(1)read() 返回值为包含整个文件内容的字符串
(2)readline() 返回值为文件下一行内容的字符串
(3)readlines()返回值为整个文件内容的列表,每项是以换行符为结尾的一行字符串
文件的写入
(1)write() 把含有本文数据或二进制数据库的字符串写入文件
(2)wirtelines() 针对列表操作,接收一个字符串列表作为参数,将它们写入文件,并且行结束符不会被自动加入。
关闭文件:切断文件与程序的联系,写入磁盘,并释放文件缓冲区
文件遍历
通用代码框架:
file = open(somefile,”r”)
For line in file.readlines():
file.close()
简化代码框架
file =open(someFile,”r”)
For line in file:
file.close()
6.文件实例一
编写程序:根据文件data.txt中的数据,使用turtle库来动态绘制图形路径
300,0,144,1,0,0
300,0,144,0,1,0
300,0,144,0,0,1
300,0,144,1,1,0
300,0,108,0,1,1
184,0,72,1,0,1
184,0, 72,0,0,0
184,0, 72,0,0,0
184,0, 72,0,0,0
元素1:路径前进像素数
元素2:转动方向,0为左,1为右
元素3:转动角度
元素4-6:绘制颜色的rgb值
IPO模式:
输入:数据文件
处理:读取数据文件,并根据数据内容和要求绘制路径
输出:构件窗口,并输出图形
#根据数据文件在窗口中动态路径绘制
import turtle
def main():
#设置窗口信息
turtle.title('数据驱动的动态路径绘制')
turtle.setup(800,600,0,0)
#设置画笔
pen=turtle.Turtle()
pen.color("red")
pen.width(5)
pen.shape("turtle")
pen.speed(5)
#读取文件
result=[]
file=open("data.txt","r")
for line in file:
result.append(list(map(float,line.split(','))))
print(result)
#动态绘制
for i in range(len(result)):
pen.color((result[i][3],result[i][4],result[i][5]))
pen.forward(result[i][0])
if result[i][1]:
pen.rt(result[i][2])
else:
pen.lt(result[i][2])
pen.goto(0,0)
if __name__== '__main__':
main()
7.文件实例二
IPO模式
输入:电话簿、邮箱地址薄文件
处理:将两个文件内容进行合并
输出:合并后包电话和邮箱地址簿的文件
#利用字符串和列表将两个通讯录文本合并为一个文本
def main():
ftele1=open('TeleAddressBook.txt','rb')
ftele2=open('EmailAddressBook.txt','rb')
ftele1.readline()#跳过第一行
ftele2.readline()
lines1 = ftele1.readlines()
lines2 = ftele2.readlines()
list1_name = []
list1_tele = []
list2_name = []
list2_email = []
for line in lines1:#获取第一个文本中的姓名和电话信息
elements = line.split()
list1_name.append(str(elements[0].decode('gbk')))
list1_tele.append(str(elements[1].decode('gbk'))) #将文本读出来的bytes转换为str类型
for line in lines2:#获取第二个文本中的姓名和邮件信息
elements = line.split()
list2_name.append(str(elements[0].decode('gbk')))
list2_email.append(str(elements[1].decode('gbk')))
###开始处理###
lines = []
lines.append('姓名\t 电话 \t 邮箱\n')
#按索引方式遍历姓名列表1
for i in range(len(list1_name)):
s= ''
if list1_name[i] in list2_name:
j = list2_name.index(list1_name[i]) #找到姓名列表1对应列表2中的姓名索引位置
s = '\t'.join([list1_name[i], list1_tele[i], list2_email[j]])
s += '\n'
else:
s = '\t'.join([list1_name[i], list1_tele[i], str(' ----- ')])
s += '\n'
lines.append(s)
#处理姓名列表2中剩余的姓名
for i in range(len(list2_name)):
s= ''
if list2_name[i] not in list1_name:
s = '\t'.join([list2_name[i], str(' ----- '), list2_email[i]])
s += '\n'
lines.append(s)
ftele3 = open('AddressBook.txt', 'w')
ftele3.writelines(lines)
ftele3.close()
ftele1.close()
ftele2.close()
print("The addressBooks are merged!")
if __name__ == "__main__":
main()