python_day3_編碼及文件操作

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


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章