奇酷教育-Python培训|UI培训|WEB大前端培训|Unity3D培训|HTML5培训|人工智能培训|JAVA开发的教育品牌

您現在所在的位置:首頁 >學習資源 > Python全棧+人工智能入門教材 > Python基礎入門教程29:企業級開發進階1:文件輸入輸出流[IO操

Python基礎入門教程29:企業級開發進階1:文件輸入輸出流[IO操

來源:奇酷教育 發表于:

農歷六月初一宜聲明變量 "a ",提交代碼;忌打DOTA,提交BUG適宜方位:坐西朝東多飲水、鮮奶,女神親近指數較高進入正題本節內容如下:什么是

農歷六月初一
宜聲明變量"a",提交代碼;忌打DOTA,提交BUG
適宜方位:坐西朝東
多飲水、鮮奶,女神親近指數較高

進入正題

本節內容如下:

  • 什么是IO
  • 文件內容操作
    • 操作文本文件
    • 操作二進制文件
  • 內存IO
    • 初步認識io模塊
  • 目錄和文件的操作
    • 初步認識os模塊
    • 文件的創建、重命名、刪除
    • 目錄的創建、重命名、刪除
  • 序列化操作

1. 什么是IO

IO:Input/Output~輸入/輸出的意思
任何編程語言,核心都是對數據的處理,對數據的處理一般情況下就是指代數據的輸入和輸出
常規情況下,我們在程序運行的過程中,將數據頻繁的輸入或者輸出到計算機的內存中,讓程序正常的運行;
由于程序中的數據并不是能持久保存的,所以在一些情況下,我們將數據輸入或者輸出到計算機中的文件中來進行永久保存;
所以各種編程語言中,都提供了豐富并且完善的輸入輸出流的API接口控制數據的輸入和輸出(讀/寫)~

運行中的程序,可以將數據臨時保存在內存中【向內存中輸出數據】,也可以將內存中的數據讀取出來在程序中使用【向程序中輸入數據】

num = 12 # 將一個數據12,賦值給變量numnum和對象12被輸出保存到計算機內存中了
print (num) # 將內存中num對應的數據12讀取到程序中進行答應,num和對應的對象數據12被輸入到程序中了

內存中的數據讀取

同樣,運行中的程序,可以將數據永久保存到文件中【向文件中輸出數據】,也可以從文件中讀取數據到程序中使用【讀取文件數據輸入到程序中】


從文件中讀寫數據

2. python中的輸入/輸出

python中提供了標準的輸入/輸出的語法結構,在之前的章節中已經進行過介紹,我們這里簡單回顧一下即可
標準輸入:input()函數操作用于接收用戶數據,保存數據的過程就可以將數據寫入到內存中
標準輸出:print()函數用于將指定的數據輸出到控制臺進行展示

msg = input("請輸入個人介紹:")
print("個人介紹:" + msg)

3. python中對文件內容的操作

文件內容也是一種數據,對數據的操作一般情況下可歸結為增刪改查四種方式
對文件內容的操作,可以歸結為讀取、覆蓋、追加的操作。

python中對文件內容的操作主要是通過open()函數進行處理的,open()函數的簡單語法結構如下:

open(file, mode="r", buffering=-1, encoding=None, errors=None, newline=None, closefd=True, opener=None)

# file:是要操作的文件,這里是完整的問文件路徑+文件名稱,如:d:/test.txt

# mode:是操作默認,默認是r,表示可讀的
####  常規選項如下:
#### r     #### 表示文件以可讀的方式打開,打開的文件只能讀取文件數據,不能修改
#### w     #### 表示文件以可寫的方式打開,可以操作文件中的數據,不能做其他操作
#### x     #### 表示文件以執行的方式打開,主要用于進行文件創建等操作
#### a     #### 表示文件內容以追加的方式打開,向文件寫入數據不會覆蓋原來的數據
#### b     #### 表示文件以二進制的方式進行處理,可以操作二進制數據
#### t     #### 表示文件以文本的方式進行處理,也是默認的方式
#### +     #### 表示文件以讀寫的方式進行處理,是rw結合起來的用法
#### U     #### 表示使用通用的內容換行的方式進行處理

# buffering:表示讀寫內容的緩沖區,如果設置為0表示關閉緩沖區,通常情況下我們會使用io.DEFAULT_BUFFER_SIZE這個默認值,在不同的操作系統中是4096/8192字節的長度

# encoding:打開文件的編碼,這個選項只能用于操作文本文件的情況下,這個選項的默認值跟文件所在的操作系統有關

# errors:這個選項主要用于在encoding選項進行編碼和解碼出現錯誤時的操作,值是一個字符串,python已經封裝了字符串對應的處理功能;常規的選項如下:
#### strict    #### 使用嚴格模式進行處理,如果出現錯誤就拋出ValueError異常信息
#### ignore    #### 忽略出現的錯誤,這里需要注意,忽略編碼錯誤會導致數據丟失的!
#### replace   #### 如果出現編碼錯誤,使用特殊符號替換錯誤的編碼,如符號?

# newline:選項用于控制mode為U時自動換行的處理,可以是如下選項中的一種
#### "None""""\n""\r""\r\n"
3.1. 操作文本文件
  • 讀取文本文件中的數據,可以使用read()函數讀取所有數據或者read(size)讀取指定長度的數據或者readlines()讀取整行數據
# 以只讀的方式打開系統中d:/test.txt文本文件,讀取其中的數據
f = open("d:/test.txt", "r")

# 讀取數據到程序中
content = f.read()

# 使用讀取到的數據
print(content)

# 操作結果,記得關閉文件哦
f.close()

# 執行結果:d:/test.txt中的數據被完整的讀取出來了
~hello python!
~輸入輸出流測試數據!

上述代碼在執行時,如果操作的文件不存在就會出現如下錯誤,請按照之前的錯誤調試章節的內容分析一下錯誤

Traceback (most recent call last):
  File "D:/resp_work/PY_WORK/備課/模塊化開發/demo06/demo01文件操作.py", line 3, in <module>
    f = open("d:/testtxt", "r")
FileNotFoundError: [Errno 2] No such file or directory: 'd:/test.txt'

另外,在讀取文件數據時,一定要注意文件的編碼格式,通常情況下都是使用當前操作系統默認的編碼,也就是在函數處理時忽略encoding選項;如同下面的情況就會出現問題:

我當前系統的默認編碼是gbk編碼,在d:盤下創建了一個test2.txt文件,文件編碼修改成了utf-8編碼,此時執行如下代碼:

f = open("d:/test2.txt", "r")
content = f.read()
print(content)
f.close()

我們可以看到和前面的代碼沒有任何區別,但是執行出現如下問題:

Traceback (most recent call last):
  File "D:/resp_work/PY_WORK/備課/模塊化開發/demo06/demo01文件操作.py", line 26, in <module>
    content = f.read()
UnicodeDecodeError: 'gbk' codec can't decode byte 0xaf in position 8: illegal multibyte sequence

這是一個什么樣的問題呢:報錯提示UnicodeDecodeError也就是編碼錯誤,我們修改程序代碼

f = open("d:/test2.txt", "r", encoding="utf-8")
content = f.read()
print(content)
f.close()

重新執行程序,數據正常讀取了

?這是新的文件內容
  • 向文本文件中寫入數據,一般情況下,可以通過write()函數或者writelines()函數向文件中寫入數據
# 以可寫的方式打開d:/test.txt文件
# 這里請注意,open()函數的mode是w模式,如果目標文件不存在就會自動創建這個文件
f = open("d:/test.txt", "w")

# 通過write()函數向文件中寫入數據
f.write("這是Python從程序中寫入到文件的數據")

# 操作完成,一定記得關閉文件哦
f.close()

python程序寫入文件的數據
  • 向文本文件中追加寫入數據,上面的代碼執行的結果,會將文件中原來的數據覆蓋掉
# 以追加內容的方式打開文件
f = open("d:/test.txt", "a")

# 向文件中追加內容
f.write("這是新的內容")

# 操作完成,記得關閉文件哦
f.close()

我們打開文件可以看到,原來的數據還在,新的數據被追加到了后面


追加寫入數據
3.2. 操作二進制文件
  • 以二進制的方式打開文件讀取文件中的數據【文本文件也可以按照二進制文件的方式讀取】
# 按照二進制的方式讀取文件,mode可以設置為rb兩個選項配合
f = open("d:/test.txt", "rb")

# 讀取文件數據
content = f.read()

# 使用文件中的數據
print(content)

# 操作完畢,記得關閉文件哦
f.close()

# 執行結果如下:
~b'\xd5\xe2\xca\xc7Python\xb3\xcc\xd0\xf2\xd0\xb4\xc8\xeb\xce\xc4\xbc\xfe\xb5\xc4\xca\xfd\xbe\xdd\xd5\xe2\xca\xc7\xd0\xc2\xb5\xc4\xc4\xda\xc8\xdd'
  • 以二進制的方式,向文件中寫入數據
# 定義要寫入文件中的內容
s = "這是python按照二進制寫入的數據"

# 按照二進制的方式打開文件追加內容,mode可以設置為ab兩個選項配合
f = open("d:/test.txt", "ab")

# 向文件中寫入數據
f.write(bytes(s, encoding="utf-8"))

# 使用文件中的數據
print(content)

# 操作完畢,記得關閉文件哦
f.close()

bytes(str, encoding="")這是一個將字符串轉換成字節數組的函數,寫入完成后查看文件內容如下:


紅色部分是寫入的二進制數據

輸入輸出流擴展:當我們開始操作文件的過程中,不可避免的由于文件是否存在,文件內存是否可寫等等為讓程序出現異常情況,所以我們要對文件操作進行異常處理,常規的處理方式有兩種,如下:

  • try-except-finally處理方式
  • with語句處理方式

第一種方式:try-except-finally包含,完成文件操作過程

try:
    f = open("d:/test.txt", "+")
    f.write("寫入文件中的內容")
    f.flush()

4. python中對內存IO

python程序對數據的輸入輸出,不一定都是針對文件的,也可以是針對內存的處理
常規情況下,python提供了StringIOBytesIO兩個內置類來進行內存中數據的處理
注意:需要引入python中的io模塊

  • StringIO:在內存中讀寫字符串的內置類
  • BytesIO:在內存中讀寫二進制數據的內置類
4.1 內存中讀寫字符串
  • 內存中讀寫字符串
    常規情況下就是創建一個StringIO對象,然后按照正常的文件讀寫的方式進行內容的讀寫即可
# 引入需要的模塊
from io import StringIO

# 創建StringIO對象
s = StringIO()

# 向內存中寫入數據
s.write("保存在內存中的數據:用戶名")
s.write("內容默認是追加的")

# 從內存中讀取數據
content = s.getvalue()
print(content)

# 操作完成,適當的時刻關閉對象
s.close()
  • 內存中操作二進制數據:和StringIO基本一致
# 引入需要的模塊
from io import BytesIO

# 定義要寫入的數據,使用bytes()函數轉換成二進制數據
s = "這是要寫入的數據"
sc = bytes(s, encoding="utf-8")

# 創建BytesIO對象
b = BytesIO()

# 向內存中寫入數據
b.write(sc)

# 從內存中讀取數據
content = b.getvalue()
print(content)

# 操作完成,適當的時刻關閉對象
s.close()

# 執行結果
~b'\xe8\xbf\x99\xe6\x98\xaf\xe8\xa6\x81\xe4\xbf\x9d\xe5\xad\x98\xe7\x9a\x84\xe6\x95\xb0\xe6\x8d\xae'

5. python中對目錄/路徑/文件夾的操作

本節內容所有的操作,其實都是和計算機交互的操作~操作計算機的內存、文件等等,python程序本身是做不了這些事情的,只是python在底層進行了和操作系統交互的功能封裝,將操作系統可以執行的諸如創建文件、文件內容操作、內存操作等等封裝成了函數

簡單了解os模塊,os模塊主要是針對操作系統的API的封裝

# 引入os模塊
import os

# 查看操作系統類型
# nt表示windows操作系統;posix表示Unix/Linux或者MacOS系統
os.name
~ 執行結果:nt

# 查看操作系統中的環境變量
os.environ
~執行結果:environ({'ALLUSERSPROFILE': 'C:\\ProgramData', 'APPDATA': 'C:\\Users\\mouwe\\AppData\\Roaming',.................'CLASSPATH': 'D:\\resp_application\\Java\\jdk1.8.0_121\\lib;.;',})
5.1. 操作文件目錄
# 查看當前操作系統的絕對路徑
os.path.abspath(".")
~ 執行結果:D:\resp_work\PY_WORK\demo
# * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
# 創建指定單級目錄
# 語法結構:os.mkdir(path, mode=, dir_fd=None)
# 描述:mkdir()函數用于使用指定的mode選項來創建一個文件夾目錄
# 參數path:用于創建文件夾的路徑
# 參數mode:用于設置的權限數字,默認777(所有權限:讀寫執行[rwx])
# * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
# 在d盤中創建一個目錄,目錄名稱為test
os.mkdir("d:/test") 

# * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
# 創建指定多級目錄
# 語法結構:os.mkdirs(path, mode=, exist_ok=False)
# 描述:makedirs()函數用于使用指定的mode選項來創建一系列文件夾目錄
# 參數path:用于創建文件夾的路徑
# 參數mode:用于設置的權限數字,默認777(所有權限:讀寫執行[rwx])
# * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
# 在d盤中創建test文件夾,文件夾中包含test2文件夾,test2中包含test3文件夾
os.mkdirs("d:/test/test2/test3")

# * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
# 重命名
# 語法結構:os.rename(old, new)
# 描述:rename()函數用于使用新名稱重命名文件夾或者文件
# 參數old:要重命名的文件
# 參數new:文件的新名稱
# * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
os.rename("d:/test", "d:/new")

# * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
# 刪除文件或者目錄
# 語法結構:os.rmdir(path)
# 描述:rmdir()函數用于刪除指定路徑的文件夾或者文件
# 參數path:要刪除的文件夾或者文件的路徑
# * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
os.rm("d:/test")

# * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
# 刪除多級文件夾
# 語法結構:os.removedirs(path)
# 描述:removedirs(path)
# 參數path:要刪除的多級文件夾路徑
# * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
os.removedirs("d:/test/test2/test3")

# * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
# 同樣在進行文件夾或者文件刪除的時候,首先要進行數據驗證
# 也就是首先判斷是文件夾/文件,才去執行刪除操作
# * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
# os.path.exists(path)函數用于判斷指定的路徑是否存在,存在返回True
res = os.path.exists("d:/test")

# os.path.isdir(path)函數用于判斷指定的路徑是否文件夾,是則返回True
res = os.path.isdir("d:/test")

# os.path.isfile(path)函數用于判斷指定的路徑是否文件,是則返回True
res = os.path.isfile("d:/test")

對于文件和文件夾的初步操作,暫時先分析到這里,再后面的章節中學習過多線程等操作之后再深入分析

>>>更多VR/AR入門教程:VR入門

 

主站蜘蛛池模板: 大型多片锯,圆木多片锯,方木多片锯,板材多片锯-祥富机械有限公司 | 焦作网 WWW.JZRB.COM| 安全光栅|射频导纳物位开关|音叉料位计|雷达液位计|两级跑偏开关|双向拉绳开关-山东卓信机械有限公司 | 安徽净化板_合肥岩棉板厂家_玻镁板厂家_安徽科艺美洁净科技有限公司 | 不锈钢闸阀_球阀_蝶阀_止回阀_调节阀_截止阀-可拉伐阀门(上海)有限公司 | 权威废金属|废塑料|废纸|废铜|废钢价格|再生资源回收行情报价中心-中废网 | 焦作网 WWW.JZRB.COM| 气体热式流量计-定量控制流量计(空气流量计厂家)-湖北南控仪表科技有限公司 | 轴承振动测量仪电箱-轴承测振动仪器-测试仪厂家-杭州居易电气 | 一体化预制泵站-一体化提升泵站-一体化泵站厂家-山东康威环保 | 登车桥动力单元-非标液压泵站-非标液压系统-深圳市三好科技有限公司 | 对照品_中药对照品_标准品_对照药材_「格利普」高纯中药标准品厂家-成都格利普生物科技有限公司 澳门精准正版免费大全,2025新澳门全年免费,新澳天天开奖免费资料大全最新,新澳2025今晚开奖资料,新澳马今天最快最新图库 | 武汉高低温试验机-现货恒温恒湿试验箱-高低温湿热交变箱价格-湖北高天试验设备 | 密集架|电动密集架|移动密集架|黑龙江档案密集架-大量现货厂家销售 | 扒渣机,铁水扒渣机,钢水扒渣机,铁水捞渣机,钢水捞渣机-烟台盛利达工程技术有限公司 | 上海办公室装修公司_办公室设计_直营办公装修-羚志悦装 | 发光字|标识设计|标牌制作|精神堡垒 - 江苏苏通广告有限公司 | 澳门精准正版免费大全,2025新澳门全年免费,新澳天天开奖免费资料大全最新,新澳2025今晚开奖资料,新澳马今天最快最新图库-首页-东莞市傲马网络科技有限公司 | 移动厕所租赁|移动卫生间|上海移动厕所租赁-家瑞租赁 | 福州仿石漆加盟_福建仿石漆厂家-外墙仿石漆加盟推荐铁壁金钢(福建)新材料科技有限公司有保障 | 合肥白癜风医院_[治疗白癜风]哪家好_合肥北大白癜风医院 | 西子馋火锅鸡加盟-太原市龙城酉鼎餐饮管理有限公司 | MVR蒸发器厂家-多效蒸发器-工业废水蒸发器厂家-康景辉集团官网 | 校园文化空间设计-数字化|中医文化空间设计-党建|法治廉政主题文化空间施工-山东锐尚文化传播公司 | 贴片电容代理-三星电容-村田电容-风华电容-国巨电容-深圳市昂洋科技有限公司 | 铝机箱_铝外壳加工_铝外壳厂家_CNC散热器加工-惠州市铂源五金制品有限公司 | 广东机电安装工程_中央空调工程_东莞装饰装修-广东粤标建设有限公司 | 安徽免检低氮锅炉_合肥燃油锅炉_安徽蒸汽发生器_合肥燃气锅炉-合肥扬诺锅炉有限公司 | 据信,上课带着跳 D 体验-别样的课堂刺激感受引发网友热议 | 档案密集柜_手动密集柜_智能密集柜_内蒙古档案密集柜-盛隆柜业内蒙古密集柜直销中心 | 分光色差仪,测色仪,反透射灯箱,爱色丽分光光度仪,美能达色差仪维修_苏州欣美和仪器有限公司 | 罐体电伴热工程-消防管道电伴热带厂家-山东沃安电气 | PVC地板|PVC塑胶地板|PVC地板厂家|地板胶|防静电地板-无锡腾方装饰材料有限公司-咨询热线:4008-798-128 | 【铜排折弯机,钢丝折弯成型机,汽车发泡钢丝折弯机,线材折弯机厂家,线材成型机,铁线折弯机】贝朗折弯机厂家_东莞市贝朗自动化设备有限公司 | bng防爆挠性连接管-定做金属防爆挠性管-依客思防爆科技 | 洛阳网站建设_洛阳网站优化_网站建设平台_洛阳香河网络科技有限公司 | 361°官方网站 | 上海地磅秤|电子地上衡|防爆地磅_上海地磅秤厂家–越衡称重 | 活性氧化铝|无烟煤滤料|活性氧化铝厂家|锰砂滤料厂家-河南新泰净水材料有限公司 | 智成电子深圳tdk一级代理-提供TDK电容电感贴片蜂鸣器磁芯lambda电源代理经销,TDK代理商有哪些TDK一级代理商排名查询。-深圳tdk一级代理 | 洗地机-全自动/手推式洗地机-扫地车厂家_扬子清洁设备 |