【20171002】python_语言设计(4)文件

来源:互联网 发布:50而知天命什么意思 编辑:程序博客网 时间:2024/06/08 04:33

1.文件
(1)文件定义:存储在外部介质上的数据或信息集合,有序信息
(2)文本显示:计算机显示功能
(3)编码:信息转化的过程
ASCII码:7个二进制位表示128个字符;
Unicode编码:跨语言跨平台统一且唯一的二进制编码,每个字符两个字节长,65536个字符的编码空间;
UTF-8编码:可变长度的Unicode;
encode() 编码
decode()解码
GBK编码:汉字内码双字节编码
(4)文件数据:
文本文件:ASCII(英文、数字),回车换行(\n)等,固定编码
二进制文件:照片、音乐、视频、程序等
节省空间,存储快、精确,编码变长灵活利用

2.文件的基本处理
(1)打开文件:磁盘文件与程序对象关联
open()
=open(,)

    r:只读    w:只写    a:附加到文件末尾    rb:只读二进制文件,文件不存在则输出错误    wb:只写二进制文件,文件不存在则自动创建文件    ab:附加到二进制文件末尾    r+:读写

(2)文件操作:读取、写入、定位、追加、计算

    read():返回值为包含整个文件内容的字符串    readline():返回值为文件下一行内容的字符串    readlines():返回值为整个文件内容的列表,每项是以换行符为结尾的一行字符串    write():把含有本文数据或二进制数据块的字符串写入文件中    writelines():针对列表操作,接受一个字符串李彪作为参数,将它们写入文件,并且行结束符不会被自动加入 
#文件遍历#文件较大时需要特别复杂file=open(someFile,"r")for line in file.readlines():    #处理一行文件内容file.close()
#文件遍历简化版file=open(someFile,"r")for line in file:    #处理一行文件内容file.close()
#文件拷贝代码实例def main():    #用户输入文件名    f1=input("enter a source file:").strip()    f2=input("enter a source file:").strip()    #打开文件    infile=open(f1,"r")    outfile=open(f2,"w")    #拷贝数据    countLines=countchars=0    for line in infile:        countLines+=1        countChars+=len(line)        outfile.write(line)    print(countLines,"lines and",countChars,"chars copied")    infile.close()    outfile.close()main()

(3)关闭文件:切断文件与程序的联系,写入磁盘,释放文件缓冲区

3.文件实例一
根据文件data.txt中的数据,使用turtile库来动态绘制图形路径,每行六个元素

元素1:路径前进像素数元素2:转动方向,0为左,1为右元素3:转动角度元素4-6:颜色rgb
#根据数据文件在窗口中动态路径绘制import turtle def main():    #设置窗口信息    turtle.title('数据驱动的动态路径绘制')    turtle.setup(800, 600, 0, 0)#800*600像素,远点在中心    #设置画笔    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])#right        else:            pen.lt(result[i][2])#left    pen.goto(0,0)#画笔定位回原点if __name__ == '__main__':    main()

4.文件实例二
多文件读写:电话簿和邮箱簿合并

#利用字符串和列表将两个通讯录文本合并为一个文本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()