python_day3_編碼及文件操作
- 2020 年 1 月 3 日
- 筆記
3.1 編碼解碼
3.2 文件操作
encode編碼
docode解碼
python2 默認 ASCII格式
# -*- coding:utf-8 -*- # 聲明程式是啥編碼格式
# 將文本解碼unicode格式
sname = name.decode("utf-8")# 必須先聲明解碼的格式是啥,比如utf-8
print(sname)
ssname = sname.encode("gbk")# 將文本編碼成gbk格式
print(ssname)
# 必須注意的是: 當gbk轉成utf-8時必須先轉成unicode格式然後再轉成uft-8 反過來也是
python3 默認 unicode
b = byte = 位元組類型 = 2進位
py3 與py2 編碼區別
encode 在編碼的同時,會把數據轉成bytes類型
decode 在解碼的同時,會把bytes類型轉成字元串
能調用方法的一定是對象
文件操作 , 下列方法都用在文件操作對象
r:讀模式操作
w:寫操作對象
a:追加添加
r+: 讀寫模式當使用write時文本會追加到最後一行的行尾
w+: 寫讀模式當使用write時,會先清空文件內容再寫到文件中
a+: 追加讀
open(1)# 打開,1表示一個漢字只列印一個字元
close# 關閉文件
write# 寫模式
ra = open('測試文件','w',encoding='utf-8')
ra.write("就是第一行測試字元串.")
print(ra)
ra.close()
列印結果: <_io.TextIOWrapper name='測試文件' mode='w' encoding='utf-8'>
ra = open('測試文件','r',encoding='utf-8')
rar = ra.read()
print(rar)
ra.close()
列印結果:就是第一行測試字元串.
raa = open('測試文件','a',encoding='utf-8')
raa.write('就是第二行測試字元串')
raa.close()
打本文本結果: 就是第一行測試字元串.就是第二行測試字元串 默認沒有換行,默認插入就是在游標處
raa = open('測試文件','a',encoding='utf-8')
raas = raa.write('n就是第二行測試字元串n')
raa.close()
與上一個不同的是,加上換行符之後它會換行
文件操作流程:
1、打開文件,得到文件句柄並賦值給一個變數;
句柄: 文件的操作對象
2、通過句柄對文件進行操作;
3、關閉文件
readline() 列印行 默認第一行
readlines() 列印全部行
# 打開一個測試文件以只讀的方式,格式為utf-8
file = open('測試文件','r',encoding='utf-8')
# 賦值一個文件變數
a = file.readlines()
# 設置一個初始值
nubmer=0
# 循環列印a文件變數的值,從第一個開始
for i in a:
# 初始值每次加1當等於2的時候使用join給這行更改配置項,並不列印/n換行符
nubmer+=1
if nubmer == 2:
i = ''.join([i.strip(),'aaaaa'])
# 每次列印這行,當第2次等於join那麼就輸出第2次變數的值
print(i.strip())
# 關閉文件操作屬性,
a.close()
修改文件
# 定義兩個變數以及文件
f_read = open('測試文件','r',encoding='utf-8')
f_write = open('測試文件2','w',encoding='utf-8')
number = 0# 設置變數為0循環某文件行數時,每次加1
for f in f_read:
number += 1
if number == 2:# 當為2時,給文件變數字元串賦值一個
f='xiong test.n'
f_write.write(f)# 最後給它寫到新的一個文件里,就能完成修改文件操作
# 管理單個對象,此方法不再需要使用close()方法
with open('測試文件','r',encoding='utf-8') as f1:
pass
# 管理多個對象
with open('測試文件','r',encoding='utf-8') as f1,open('測試文件2','w',encoding='utf-8') as f2 :
pass
tell 檢測游標位置
print(file.read(4))
print(file.tell())
列印結果:就是第一
12一個中文3個字元,uft8格式
文件對象.seek() 調整游標位置
print(file.seek(1))
print(file.tell())
列印結果:1
1
# 一個類型tail -1的腳本
f=open('file3','rb') for i in f: num_bytes=-10 while True: data=f.readlines() if len(data) > 1: print('最後一行的結果是:%s'%(data[-1].decode('utf-8'))) break num_bytes*=2