欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

史上最全Python文件類型讀寫庫大盤點

 更新時間:2023年05月18日 16:30:42   作者:techlead_krischang  
這篇文章主要為大家詳細介紹了史上最全Python文件類型讀寫庫大盤點,包含常用和不常用的大量文件格式,文本、音頻、視頻應(yīng)有盡有,廢話不多說,走起來

先給大家快捷總結(jié):

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

正文開始!

1. 文本文件

在Python中,處理文本文件是最基礎(chǔ)的文件操作,我們使用內(nèi)置的open函數(shù)打開一個文件,然后使用文件對象的read或write方法進行讀寫操作。

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

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

2. CSV文件

CSV(Comma-Separated Values)文件是一種常用的數(shù)據(jù)交換格式,每行表示一條記錄,各字段之間由逗號分隔。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函數(shù)分別返回一個寫入器和讀取器對象,我們可以使用這些對象進行CSV文件的讀寫操作。

3. JSON文件

JSON(JavaScript Object Notation)是一種輕量級的數(shù)據(jù)交換格式,易于閱讀和編寫,同時也易于機器解析和生成。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函數(shù)分別用于將Python對象轉(zhuǎn)換為JSON格式并寫入文件,以及從文件中讀取JSON數(shù)據(jù)并轉(zhuǎn)換為Python對象。

4. XML文件

XML(eXtensible Markup Language)是一種標記語言,可以用來描述數(shù)據(jù)的結(jié)構(gòu)。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模塊創(chuàng)建一個XML文件的樹形結(jié)構(gòu),然后使用ElementTree對象的write方法將其寫入文件。讀取XML一個ElementTree對象,然后通過遍歷這個對象來讀取XML數(shù)據(jù)。

5.二進制文件

二進制文件是直接包含二進制數(shù)據(jù)的文件,例如圖像文件、音頻文件等。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類型的數(shù)據(jù)進行二進制寫操作。

6. 圖片文件

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

from PIL import Image

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

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

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

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

7. Word文件

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

from docx import Document
# 創(chuàng)建新的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)

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

8. XLSX文件

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

from openpyxl import Workbook, load_workbook

# 創(chuàng)建新的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)

在這里,我們首先創(chuàng)建一個Workbook對象和Worksheet對象,然后使用字典方式訪問單元格并賦值,最后使用save方法保存工作簿。讀取Excel文件時,我們使用load_workbook函數(shù)加載工作簿,然后訪問激活的工作表的單元格。

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不能直接創(chuàng)建PDF文件,但可以合并、裁剪和旋轉(zhuǎn)PDF文件

在這里,我們使用PdfFileReader對象讀取PDF文件,然后使用getPage方法獲取某一頁,最后使用extractText方法提取文本。注意PyPDF2不能直接創(chuàng)建PDF文件,但可以合并、裁剪和旋轉(zhuǎn)PDF文件。

10. SQLite數(shù)據(jù)庫文件

SQLite是一種嵌入式數(shù)據(jù)庫,它的數(shù)據(jù)庫全都保存在一個單獨的文件中。Python的sqlite3模塊提供了對SQLite數(shù)據(jù)庫的支持。

import sqlite3

# 創(chuàng)建并寫入SQLite數(shù)據(jù)庫
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數(shù)據(jù)庫
conn = sqlite3.connect('example.db')
c = conn.cursor()
for row in c.execute("SELECT * FROM test"):
    print(row)
conn.close()

在這里,我們首先創(chuàng)建一個數(shù)據(jù)庫連接和游標對象,然后使用execute方法執(zhí)行SQL語句,最后使用commit方法提交事務(wù)。讀取SQLite數(shù)據(jù)庫時,我們遍歷execute方法的結(jié)果,打印出每一行。

11. 音頻文件

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

from pydub import AudioSegment

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

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

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

在這里,AudioSegment.from_file函數(shù)用于讀取音頻文件。pydub庫提供了豐富的音頻處理功能,例如反轉(zhuǎn)、裁剪、合并等。最后使用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函數(shù)用于讀取視頻文件。moviepy庫提供了豐富的視頻處理功能,例如裁剪、拼接、添加音頻等。最后使用write_videofile方法保存視頻文件。

13. HTML文件

HTML是網(wǎng)頁的主要構(gòu)成元素。我們可以使用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不能直接創(chuàng)建HTML文件,但可以修改HTML文件

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

14. YAML文件

YAML(YAML Ain't Markup Language)是一種直觀的數(shù)據(jù)序列化格式,常用于配置文件。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函數(shù)分別用于將Python對象轉(zhuǎn)換為YAML格式并寫入文件,以及從文件中讀取YAML數(shù)據(jù)并轉(zhuǎn)換為Python對象。

15. ZIP文件

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

from zipfile import ZipFile

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

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

在這里,我們使用ZipFile對象創(chuàng)建一個ZIP文件,然后使用write方法添加文件。讀取ZIP文件時,我們使用namelist方法列出所有文件。

One More Thing

在處理文件時,一個常被忽視但又極其有用的技巧是使用Python的pathlib模塊來處理文件路徑。pathlib模塊提供了一種面向?qū)ο蟮姆绞絹硖幚砦募湍夸浡窂?,使得路徑的處理變得更加直觀和簡潔。 

from pathlib import Path

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

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

# 獲取文件的后綴名
print(p.suffix)

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

以上就是史上最全Python文件類型讀寫庫大盤點的詳細內(nèi)容,更多關(guān)于Python文件讀寫的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • Python判斷字符串是否為空和null方法實例

    Python判斷字符串是否為空和null方法實例

    這篇文章主要介紹了Python判斷字符串是否為空和null,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-04-04
  • Python中一行和多行import模塊問題

    Python中一行和多行import模塊問題

    我們通過本篇文章給大家分析了為什么Python不建議使用一行import所有模塊的原因,有興趣的朋友學習下。
    2018-04-04
  • 使用 Python 玩轉(zhuǎn) GitHub 的貢獻板(推薦)

    使用 Python 玩轉(zhuǎn) GitHub 的貢獻板(推薦)

    這篇文章主要介紹了使用 Python 玩轉(zhuǎn) GitHub 的貢獻板的相關(guān)知識,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-04-04
  • Win10下配置tensorflow-gpu的詳細教程(無VS2015/2017)

    Win10下配置tensorflow-gpu的詳細教程(無VS2015/2017)

    這篇文章主要介紹了Win10下配置tensorflow-gpu(無VS2015/2017),本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-07-07
  • 王純業(yè)的Python學習筆記 下載

    王純業(yè)的Python學習筆記 下載

    這篇文章主要介紹了王純業(yè)的Python學習筆記 下載
    2007-02-02
  • python實現(xiàn)切割url得到域名、協(xié)議、主機名等各個字段的例子

    python實現(xiàn)切割url得到域名、協(xié)議、主機名等各個字段的例子

    今天小編就為大家分享一篇python實現(xiàn)切割url得到域名、協(xié)議、主機名等各個字段的例子,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-07-07
  • 詳解numpy的argmax的具體使用

    詳解numpy的argmax的具體使用

    這篇文章主要介紹了詳解numpy的argmax的具體使用,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-05-05
  • Python Numpy中ndarray的常見操作

    Python Numpy中ndarray的常見操作

    這篇文章主要介紹了Python Numpy中ndarray的常見操作,NumPy是Python的一種開源的數(shù)值計算擴展,更多詳細內(nèi)容需要的朋友可以參考一下
    2022-07-07
  • python線程中同步鎖詳解

    python線程中同步鎖詳解

    這篇文章主要為大家詳細介紹了python線程中同步鎖的相關(guān)資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-04-04
  • Python爬蟲之Requests庫基本使用詳解

    Python爬蟲之Requests庫基本使用詳解

    這篇文章主要介紹了Python爬蟲之Requests庫基本使用詳解,Requests 庫是在 urllib 模塊的基礎(chǔ)上開發(fā)而來,繼承了urllib.request的所有特性,與urllib.request 相比,Requests 在使用時更加簡潔方便、快捷,所以 Requests 庫在編寫爬蟲程序時使用較多,需要的朋友可以參考下
    2023-09-09

最新評論