< Python全景系列-4 > 史上最全文件類型讀寫庫大盤點!什麼?還包括音頻、視頻?

来源:https://www.cnblogs.com/xfuture/archive/2023/05/18/17411291.html
-Advertisement-
Play Games

介紹史上最全PYTHON文件類型讀寫庫大盤點!包含常用和不常用的大量文件格式!文本、音頻、視頻應有盡有!廢話不多說!走起來! ...


歡迎來到我們的系列博客《Python全景系列》!在這個系列中,我們將帶領你從Python的基礎知識開始,一步步深入到高級話題,幫助你掌握這門強大而靈活的編程語言!

本文系列第四篇,介紹史上最全PYTHON文件類型讀寫庫大盤點!包含常用和不常用的大量文件格式!文本、音頻、視頻應有盡有!廢話不多說!走起來!

先給大家快捷總結:

文件格式Python庫
文本文件 內置open函數
CSV文件 csv
JSON文件 json
XML文件 xml.etree.ElementTree
二進位文件 內置open函數
圖片文件 PIL (Python Imaging Library)
Word文件 python-docx
XLSX文件 openpyxl
PDF文件 PyPDF2
SQLite資料庫文件 sqlite3
音頻文件 pydub
視頻文件 moviepy
HTML文件 BeautifulSoup
YAML文件 pyyaml
ZIP文件 zipfile

 

正文開始!

1. 文本文件

在Python中,處理文本文件是最基礎的文件操作,我們使用內置的open函數打開一個文件,然後使用文件對象的read或write方法進行讀寫操作。

# 寫入文本文件
with open('example.txt', 'w') as f:
    f.write('Hello, Python!')

# 讀取文本文件
with open('example.txt', 'r') as f:
    print(f.read())

 

在這裡,open函數的第一個參數是文件名,第二個參數是文件模式,其中'r'代表讀模式,'w'代表寫模式。使用'with'語句可以確保文件在操作完成後被正確關閉。這是一個標準的文件操作模式,也適用於其他類型的文件。

 

2. CSV文件

CSV(Comma-Separated Values)文件是一種常用的數據交換格式,每行表示一條記錄,各欄位之間由逗號分隔。Python的csv模塊提供了用於讀寫CSV文件的工具。

 

import csv

# 寫入CSV文件
with open('example.csv', 'w', newline='') as f:
    writer = csv.writer(f)
    writer.writerow(['name', 'age'])
    writer.writerow(['Alice', 20])
    writer.writerow(['Bob', 25])

# 讀取CSV文件
with open('example.csv', 'r') as f:
    reader = csv.reader(f)
    for row in reader:
        print(row)

 

 

 

 

這裡,csv.writer和csv.reader函數分別返回一個寫入器和讀取器對象,我們可以使用這些對象進行CSV文件的讀寫操作。

 

3. JSON文件

JSON(JavaScript Object Notation)是一種輕量級的數據交換格式,易於閱讀和編寫,同時也易於機器解析和生成。Python的json模塊提供了用於讀寫JSON文件的工具。

import json

# 寫入JSON文件
data = {
    'name': 'Alice',
    'age': 20,
}
with open('example.json', 'w') as f:
    json.dump(data, f)

# 讀取JSON文件
with open('example.json', 'r') as f:
    data = json.load(f)
    print(data)

 

在這裡,json.dump和json.load函數分別用於將Python對象轉換為JSON格式並寫入文件,以及從文件中讀取JSON數據並轉換為Python對象。

 

4. XML文件

XML(eXtensible Markup Language)是一種標記語言,可以用來描述數據的結構。Python的xml模塊提供了用於讀寫XML文件的工具。

from xml.etree import ElementTree as ET

# 寫入XML文件
root = ET.Element('root')
child = ET.Element('child')
child.text = 'Hello, Python!'
root.append(child)
tree = ET.ElementTree(root)
tree.write('example.xml')

# 讀取XML文件
tree = ET.parse('example.xml')
root = tree.getroot()
for child in root:
    print(child.text)

 

在這裡,我們使用xml.etree.ElementTree模塊創建一個XML文件的樹形結構,然後使用ElementTree對象的write方法將其寫入文件。讀取XML一個ElementTree對象,然後通過遍歷這個對象來讀取XML數據。

 

5.二進位文件

二進位文件是直接包含二進位數據的文件,例如圖像文件、音頻文件等。Python使用'b'模式打開二進位文件,然後使用文件對象的read或write方法進行讀寫操作。

# 寫入二進位文件
data = b'Hello, Python!'
with open('example.bin', 'wb') as f:
    f.write(data)

# 讀取二進位文件
with open('example.bin', 'rb') as f:
    data = f.read()
    print(data)

 

在這裡,'wb'和'rb'分別代表二進位寫模式和二進位讀模式。註意我們使用bytes類型的數據進行二進位寫操作。

 

6. 圖片文件

處理圖片文件一般需要藉助第三方庫,如PIL(Python Imaging Library)。

from PIL import Image

# 讀取圖片文件
img = Image.open('example.jpg')

# 修改圖片
img = img.rotate(45)  # 旋轉45度

# 寫入圖片文件
img.save('example_rotated.jpg')

 

 

這裡,Image.open和Image.save函數分別用於讀取和保存圖片文件。PIL庫提供了豐富的圖像處理功能,例如旋轉、裁剪、縮放等。

 

7. Word文件

處理Word文件,我們可以使用python-docx庫,這是一個創建、修改和提取Microsoft Word文件的Python庫。

from docx import Document

# 創建新的Word文件
doc = Document()
doc.add_paragraph('Hello, Python!')
doc.save('example.docx')

# 讀取Word文件
doc = Document('example.docx')
for para in doc.paragraphs:
    print(para.text)

 

 

在這裡,我們首先創建一個Document對象,然後使用add_paragraph方法添加段落,最後使用save方法保存文檔。讀取Word文件時,我們遍歷Document對象的paragraphs屬性,列印出每個段落的文本。

 

8. XLSX文件

處理Excel文件,我們可以使用openpyxl庫,這是一個讀寫Excel 2010 xlsx/xlsm/xltx/xltm文件的Python庫。

from openpyxl import Workbook, load_workbook

# 創建新的Excel文件
wb = Workbook()
ws = wb.active
ws['A1'] = 'Hello,'
ws['B1'] = 'Python!'
wb.save('example.xlsx')

# 讀取Excel文件
wb = load_workbook('example.xlsx')
ws = wb.active
print(ws['A1'].value, ws['B1'].value)

 

 

在這裡,我們首先創建一個Workbook對象和Worksheet對象,然後使用字典方式訪問單元格並賦值,最後使用save方法保存工作簿。讀取Excel文件時,我們使用load_workbook函數載入工作簿,然後訪問激活的工作表的單元格。

 

9. PDF文件

PDF是一種常見的文件格式,我們可以使用Python的PyPDF2庫來處理PDF文件。

import PyPDF2

# 讀取PDF文件
with open('example.pdf', 'rb') as f:
    reader = PyPDF2.PdfFileReader(f)
    page = reader.getPage(0)
    print(page.extractText())

# 註意:PyPDF2不能直接創建PDF文件,但可以合併、裁剪和旋轉PDF文件

 

 

在這裡,我們使用PdfFileReader對象讀取PDF文件,然後使用getPage方法獲取某一頁,最後使用extractText方法提取文本。註意PyPDF2不能直接創建PDF文件,但可以合併、裁剪和旋轉PDF文件。

 

10. SQLite資料庫文件

SQLite是一種嵌入式資料庫,它的資料庫全都保存在一個單獨的文件中。Python的sqlite3模塊提供了對SQLite資料庫的支持。

import sqlite3

# 創建並寫入SQLite資料庫
conn = sqlite3.connect('example.db')
c = conn.cursor()
c.execute("CREATE TABLE test (name text, age integer)")
c.execute("INSERT INTO test VALUES ('Alice', 20)")
conn.commit()
conn.close()

# 讀取SQLite資料庫
conn = sqlite3.connect('example.db')
c = conn.cursor()
for row in c.execute("SELECT * FROM test"):
    print(row)
conn.close()

 

 

在這裡,我們首先創建一個資料庫連接和游標對象,然後使用execute方法執行SQL語句,最後使用commit方法提交事務。讀取SQLite資料庫時,我們遍歷execute方法的結果,列印出每一行。

 

 

11. 音頻文件

處理音頻文件,我們可以使用pydub庫,這是一個處理音頻的Python庫。

from pydub import AudioSegment

# 讀取音頻文件
audio = AudioSegment.from_file('example.mp3')

# 修改音頻
audio = audio.reverse()  # 反轉音頻

# 保存音頻文件
audio.export('example_reversed.mp3', format='mp3')

 

 

在這裡,AudioSegment.from_file函數用於讀取音頻文件。pydub庫提供了豐富的音頻處理功能,例如反轉、裁剪、合併等。最後使用export方法保存音頻文件。

 

12. 視頻文件

處理視頻文件,我們可以使用moviepy庫,這是一個用於視頻編輯的Python庫。

from moviepy.editor import VideoFileClip

# 讀取視頻文件
clip = VideoFileClip('example.mp4')

# 修改視頻
clip = clip.subclip(10, 20)  # 截取第10秒到第20秒的片段

# 保存視頻文件
clip.write_videofile('example_subclip.mp4')

 

 

在這裡,VideoFileClip函數用於讀取視頻文件。moviepy庫提供了豐富的視頻處理功能,例如裁剪、拼接、添加音頻等。最後使用write_videofile方法保存視頻文件。

13. HTML文件

HTML是網頁的主要構成元素。我們可以使用Python的beautifulsoup庫解析HTML文件。

from bs4 import BeautifulSoup

# 讀取HTML文件
with open('example.html', 'r') as f:
    soup = BeautifulSoup(f, 'html.parser')

# 解析HTML
print(soup.title.text)  # 列印標題

# 註意:BeautifulSoup不能直接創建HTML文件,但可以修改HTML文件

 

 

在這裡,我們使用BeautifulSoup對象解析HTML文件,然後通過標簽名訪問HTML元素。

 

14. YAML文件

YAML(YAML Ain't Markup Language)是一種直觀的數據序列化格式,常用於配置文件。Python的pyyaml庫提供了用於讀寫YAML文件的工具。

import yaml

# 寫入YAML文件
data = {'name': 'Alice', 'age': 20}
with open('example.yaml', 'w') as f:
    yaml.dump(data, f)

# 讀取YAML文件
with open('example.yaml', 'r') as f:
    data = yaml.load(f, Loader=yaml.FullLoader)
    print(data)

 

 

在這裡,yaml.dump和yaml.load函數分別用於將Python對象轉換為YAML格式並寫入文件,以及從文件中讀取YAML數據並轉換為Python對象。

 

15. ZIP文件

ZIP是一種常用的壓縮文件格式。Python的zipfile模塊提供了用於讀寫ZIP文件的工具。

from zipfile import ZipFile

# 創建ZIP文件
with ZipFile('example.zip', 'w') as zf:
    zf.write('example.txt')

# 讀取ZIP文件
with ZipFile('example.zip', 'r') as zf:
    print(zf.namelist())

 

在這裡,我們使用ZipFile對象創建一個ZIP文件,然後使用write方法添加文件。讀取ZIP文件時,我們使用namelist方法列出所有文件。

 

One More Thing

在處理文件時,一個常被忽視但又極其有用的技巧是使用Python的pathlib模塊來處理文件路徑。pathlib模塊提供了一種面向對象的方式來處理文件和目錄路徑,使得路徑的處理變得更加直觀和簡潔。 

from pathlib import Path

# 創建Path對象
p = Path('example.txt')

# 檢查文件是否存在
if p.exists():
    print('File exists.')

# 獲取文件的尾碼名
print(p.suffix)

 

 

在這個例子中,我們使用Path對象表示一個文件路徑,然後使用Path對象的方法和屬性來進行各種操作,例如檢查文件是否存在,獲取文件的尾碼名等。這是一個非常強大且易用的模塊,可以極大地提高我們處理文件路徑的效率。

 

以上就是Python全文件格式輸入輸出的介紹。希望通過本文,你能夠對Python的文件操作有更深入的理解,並能夠在實際編程中靈活運用。如果你有任何問題或想法,歡迎在評論區留言分享。

【第一時間獲得Python全視角更新信息,請關註本人微信公眾號: Python全視角】
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • Python字元串替換筆記主要展示瞭如何在Python中替換字元串。Python中有以下幾種替換字元串的方法,本文主要介紹前三種。 replace方法(常用) translate方法 re.sub方法 字元串切片(根據Python字元串切片方法替換字元) 1.replace方法 Python rep ...
  • 本文將演示在本地的 python 項目中調用 ChatGPT 模型 前言 作為一名程式員,在開發過程當中時常需要使用 ChatGPT 來完成一些任務,但總是使用網頁交互模式去 Web 端訪問 ChatGPT 是很麻煩的,這時候我們可以使用代碼來調用 ChatGPT 模型,以實現在本地和 Web 端一 ...
  • 摘要:這篇文章詳細介紹了頂帽運算和底帽運算,它們將為後續的圖像分割和圖像識別提供有效支撐。 本文分享自華為雲社區《[Python從零到壹] 四十九.圖像增強及運算篇之頂帽運算和底帽運算》,作者:eastmount。 數學形態學(Mathematical Morphology)是一種應用於圖像處理和模 ...
  • 基於java的校園二手交易系統或跳蚤市場設計與實現,java二手交易平臺,二手商城,交易商城,大學生交易平臺,springboot二手交易系統,二手交易平臺,購物平臺,大學生跳蚤平臺設計與實現,閑置物品交易平臺,校園閑置二手。 ...
  • Lambda 表達式(lambda expression)是一個匿名函數,Lambda表達式基於數學中的λ演算得名,直接對應於其中的lambda抽象(lambda abstraction),是一個匿名函數,即沒有函數名的函數。Lambda表達式可以表示閉包,和傳統數學上的意義有區別。 文末有本文重點 ...
  • Java是通過垃圾回收機制回收記憶體,C/C++是通過malloc,free,new,delete手動管理空間。那麼在JNI層,同時存在Java和C/C++的空間時,該如何進行空間的管理呢?本文參考Oracle的官方文檔,對JNI層中空間的管理進行說明。明確哪些內容需要手動調用Delete,哪些不需要... ...
  • 數據集拆分是將一個大型的數據集拆分為多個較小的數據集,可以讓數據更加清晰易懂,也方便對單個數據集進行分析和處理。 同時,分開的數據集也可以分別應用不同的數據分析方法進行處理,更加高效和專業。 數據集合併則是將多個數據集合併成一個大的數據集,可以提供更全面的信息,也可以進行更綜合的數據分析。 同時,數 ...
  • ###第1關 類的繼承 package step1; import java.util.Scanner; class Person { /********** Begin **********/ // 自行設計類的實現 //姓名 private String name; //性別 private S ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...