天天看點

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)

列印結果:就是第一行測試字元串.

raa = open('測試檔案','a',encoding='utf-8')

raa.write('就是第二行測試字元串')

raa.close()

打本文本結果: 就是第一行測試字元串.就是第二行測試字元串   預設沒有換行,預設插入就是在光标處

raas = raa.write('\n就是第二行測試字元串\n')

與上一個不同的是,加上換行符之後它會換行

檔案操作流程:

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 :

tell 檢測光标位置

print(file.read(4))

print(file.tell())

列印結果:就是第一

12一個中文3個字元,uft8格式

檔案對象.seek()   調整光标位置

print(file.seek(1))

列印結果:1

  1

# 一個類型tail -1的腳本 

<code>f</code><code>=</code><code>open</code><code>(</code><code>'file3'</code><code>,</code><code>'rb'</code><code>)</code>

<code>for</code> <code>i </code><code>in</code> <code>f:</code>

<code>    </code><code>num_bytes</code><code>=</code><code>-</code><code>10</code>

<code>    </code><code>while</code> <code>True</code><code>:</code>

<code>        </code><code>data</code><code>=</code><code>f.readlines()</code>

<code>        </code><code>if</code> <code>len</code><code>(data) &gt; </code><code>1</code><code>:</code>

<code>            </code><code>print</code><code>(</code><code>'最後一行的結果是:%s'</code><code>%</code><code>(data[</code><code>-</code><code>1</code><code>].decode(</code><code>'utf-8'</code><code>)))</code>

<code>            </code><code>break</code>

<code>        </code><code>num_bytes</code><code>*</code><code>=</code><code>2</code>

<code></code>

     本文轉自812374156 51CTO部落格,原文連結:http://blog.51cto.com/xiong51/1963608,如需轉載請自行聯系原作者