一、文件操作
1,讀文件
在以'r'讀模式打開文件以后可以調用read函數一次性將文件內容全部讀出,也可以指定每次read讀多少字節,例如:
1 #coding:utf-8 2 fn='test1.py' 3 fp=open(fn,'r') #以讀的方式打開文件,文件必須首先存在和,.文件在同一目錄下py 4 print 'reading pos:',fp.tell() 5 r=fp.read(20) #讀取文件內容返回字符串 6 print 'have read:\"'+r+'\'' 7 print 'reading pos:',fp.tell() 8 print fp.read() 9 fp.close()
2,寫文件
如果想將某些內容寫入文件,可以以'w'寫的方式打開文件(如果文件不存在會創建),並且清空文件之前的內容。
1 fw='test.txt' 2 fp=open(fw,'w') 3 fp.write('www.google.com') 4 fp.close()
3,讀寫文件r+,w+
二者區別在於:r+是必須針對已存在的文件;w+可以創建未存在的文件。
1 fn='rplus.txt' 2 fp=open(fn,'w+') 3 r=fp.read(12) 4 print r 5 fp.close()
4,追加寫入文件a
‘w'寫模式打開的文件只能把內容寫入文件,原有內容將被清除,若想保留,則用‘a'追加寫模式。
1 fn='rplus.txt' 2 fp=open(fn,'w+') 3 fp.write('aaaaa\n') 4 fp.close() 5 6 fa=open('rplus.txt','a') 7 fa.write('bbbbb\n') 8 fa.close() 9 10 fa=open(fn,'r') 11 r=fa.read() 12 print r 13 fa.close()
二,格式化讀寫文件
1,格式化寫文件
調用write函數,使用格式化控制符來格式化寫入字符串。
1 fn='wformat.txt' 2 fw=open(fn,'w') 3 fw.write('%10s\t %3s\t %6s\n'%('name','age','sex')) 4 fw.write('%10s\t %3s\t %6s\n'%('張三',78,'male')) 5 fw.write('%10s\t %3s\t %6s\n'%('李四',50,'male')) 6 fw.write('%10s\t %3s\t %6s\n'%('王五',80,'male')) 7 fw.write('%10s\t %3s\t %6s\n'%('張強',90,'female')) 8 fw.close()
2,讀成列表
文件的readlines函數可以將文本文件的若干行文本一一映射成列表的若干項,即文本文件的每一行映射成列表的一個數據項,每個數據項都是字符串。
1 fr=open('templist.txt','r') 2 print fr.readlines() 3 fr.close()
結果如下:
1 >>> 2 [' aaaaaaaa\n', ' bbbbbbbb\n', ' cccccccc']
3,讀成一行文件
調用readline函數讀一行內容,而read函數是一次性將文件的內容全部讀回。另外,可以用strip函數去掉\n和空格。
1 fr=open('templist.txt','r') 2 print fr.readline().strip().strip('\n') 3 print fr.readline().strip().strip('\n') 4 print fr.readline().strip().strip('\n') 5 fr.close()
結果如下:
1 >>> 2 aaaaaaaa 3 bbbbbbbb 4 cccccccc
4,split格式化數據
1 fr=open('wformat.txt','r') 2 line1=fr.readline() 3 print line1 4 line2=fr.readline() 5 print line2 6 print line2.split('\t') 7 fr.close()
結果如下:
1 >>> 2 name age sex 3 4 張三 78 male 5 6 [' \xd5\xc5\xc8\xfd', ' 78', ' male\n']
讀取文件(格式化)的內容:
1 fr=open('wformat.txt','r') 2 while (1==1): 3 line=fr.readline() 4 if(line==''): 5 break 6 else: 7 print line 8 fr.close() 9 10 >>> ================================ RESTART ================================ 11 >>> 12 name age sex 13 14 張三 78 male 15 16 李四 50 male 17 18 王五 80 male 19 20 張強 90 female 21 22 >>>
5,讀寫子目錄文件
只需指定文件時描述好路徑即可,但是注意兩點:1)轉義字符的問題;2)不能創建文件夾,文件夾必須預先存在。
1 fn='c:\\test.txt' 2 fp=open(fn,'w+') 3 fp.write('www.python.com') 4 fp.close()
三,字典及其基本操作
1,字典定義
字典:由一對稱之為鍵和值構成,用逗號間隔起來,用花括號括起來就構成了字典。語法結構:
dict_name={key:value,key:value,key:value,……}
字典的數據項的值可以是字典,列表等數據類型。
2,基礎操作
1)字典長度:
len函數可以測得字典的數據項個數。
1 >>> dict1={'a':'b','name':'jeap',12:34} 2 >>> len(dict1) 3 3
2)元素值的訪問:
Python的字典可以通過鍵獲取其所對應的值,而序列型數據字符串,列表則是通過index索引來獲取的。字典的元素的關系比較稀松,是無序的。
1 >>> dict1={'a':'b','name':'jeap',12:34} 2 >>> print dict1['a'],dict1[12] 3 b 34
3)元素值的修改:
通過鍵獲取修改所對應的值。
1 >>> dict1['a']='hello' 2 >>> print dict1 3 {'a': 'hello', 12: 34, 'name': 'jeap'}
4)元素項的刪除:
通過del 字典名[鍵]來刪除字典里的元素。
1 >>> del dict1[12] 2 >>> print dict1 3 {'a': 'hello', 'name': 'jeap'}
5)元素項的增加:
通過字典名[新鍵]賦值的方式在字典里新增一個數據項。
1 >>> dict1['QQ']='649414754' 2 >>> print dict1 3 {'a': 'hello', 'QQ': '649414754', 'name': 'jeap'} 4 >>> dict1['sex']='F' 5 >>> print dict1 6 {'a': 'hello', 'QQ': '649414754', 'name': 'jeap', 'sex': 'F'}
6)in運算:
判斷某鍵是否存在於字典里。
1 >>> 'name' in dict1 2 True 3 >>> 'F' in dict1 4 False
注意:in運算查找的是Key值,而非value值。
四,字典的相關函數
1)clear函數:清空字典數據項。
1 >>> print dict1 2 {'a': 'hello', 'QQ': '649414754', 'name': 'jeap', 'sex': 'F'} 3 >>> dict1.clear() 4 >>> print dict1 5 {}
2)copy函數:字典復制,與源對象間的關系是備份關系。
1 >>> dict1={'a': 'hello', 'QQ': '649414754', 'name': 'jeap', 'sex': 'F'} 2 >>> dict2=dict1.copy() 3 >>> print dict2 4 {'a': 'hello', 'QQ': '649414754', 'name': 'jeap', 'sex': 'F'}
3)get函數:獲取某鍵鎖對應的值,等價於dict_name[鍵]。
1 {'a': 'hello', 'QQ': '649414754', 'name': 'jeap', 'sex': 'F'} 2 >>> dict1.get('QQ') 3 '649414754'
4)keys函數:獲取字典所有的key。
1 >>> dict1.keys() 2 ['a', 'QQ', 'name', 'sex']
5)values函數:獲取字典所有的value。
1 >>> dict1.values() 2 ['hello', '649414754', 'jeap', 'F']
6)intems函數:獲取字典所有的key-value。
1 >>> dict1.items() 2 [('a', 'hello'), ('QQ', '649414754'), ('name', 'jeap'), ('sex', 'F')]
7)update函數:更新字典里某鍵(key)的鍵值(value),如果更新的key原字典沒有,則update就向字典里添加一項數據。
1 >>> new={'age':32} #原字典沒有,新增 2 >>> add={'name':'張三'} #原字典存在,更新'jeap'為'張三' 3 >>> dict1.update(new) 4 >>> dict1.update(add) 5 >>> print dict1 6 {'a': 'hello', 'QQ': '649414754', 'name': '\xd5\xc5\xc8\xfd', 'age': 32, 'sex': 'F'}
8)dict函數:創建字典。
下面舉例三種創建字典的方法:
1 >>> d0=dict() #創建空字典 2 >>> print d0 3 {} 4 >>> d1=dict(name='zhangsan',QQ='123456789',age=23)#通過賦值創建字典 5 >>> print d1 6 {'QQ': '123456789', 'age': 23, 'name': 'zhangsan'} 7 >>> val=['lisi','649414754',25] 8 >>> print val 9 ['lisi', '649414754', 25] 10 >>> key=range(1,4) 11 >>> d2=dict(zip(key,val))#使用一對列表創建字典 12 >>> print d2 13 {1: 'lisi', 2: '649414754', 3: 25}
9)pop和popitem函數:pop方法通過鍵key獲取其值value並從字典中刪除該數據項;popitem函數則是隨機移除一個數據項,返回值是元組。
1 >>> val=['Tom','Jack','Rose','John','Mark'] 2 >>> key=range(1,6) 3 >>> dic=dict(zip(key,val)) 4 >>> print dic 5 {1: 'Tom', 2: 'Jack', 3: 'Rose', 4: 'John', 5: 'Mark'} 6 >>> dic.pop(2) 7 'Jack' 8 >>> dic.popitem() 9 (1, 'Tom') 10 >>> print dic 11 {3: 'Rose', 4: 'John', 5: 'Mark'}
10)實踐應用:字典和for循環遍歷字典。
i)通過in運算和鍵,來訪問字典的值。
1 >>> key=range(1,6) 2 >>> val=['Tom','Jack','Rose','John','Mark'] 3 >>> dic=dict(zip(key,val)) 4 >>> for x in dic: 5 print dic[x] 6 7 8 Tom 9 Jack 10 Rose 11 John 12 Mark
ii)通過items函數返回值為(key,value)元組組成的列表來訪問。
1 >>> print dic.items() 2 [(1, 'Tom'), (2, 'Jack'), (3, 'Rose'), (4, 'John'), (5, 'Mark')] 3 >>> for (k,v) in dic.items(): 4 print 'dic[',k,']=',v 5 6 7 dic[ 1 ]= Tom 8 dic[ 2 ]= Jack 9 dic[ 3 ]= Rose 10 dic[ 4 ]= John 11 dic[ 5 ]= Mark 12 >>>
五,小結
本章主要介紹python開發的進階知識,文件的基本操作,字典的相關概念,基本操作運算和相關函數,為以后實戰應用做一個鋪墊,本章存在的遺留問題是,如何調用不在同一目錄文件下的.py自定義模塊?按照書上的代碼未能實現。
