歡迎來到我們的系列博客《Python全景系列》!在這個(gè)系列中,我們將帶領(lǐng)你從Python的基礎(chǔ)知識開始,一步步深入到高級話題,幫助你掌握這門強(qiáng)大而靈活的編程語言!
本文系列第四篇,介紹史上最全PYTHON文件類型讀寫庫大盤點(diǎn)!包含常用和不常用的大量文件格式!文本、音頻、視頻應(yīng)有盡有!廢話不多說!走起來!
先給大家快捷總結(jié):
文件格式 | Python庫 |
---|---|
文本文件 | 內(nèi)置open函數(shù) |
CSV文件 | csv |
JSON文件 | json |
XML文件 | xml.etree.ElementTree |
二進(jìn)制文件 | 內(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 |
?文章來源:http://www.zghlxwxcb.cn/news/detail-449034.html
正文開始!
1. 文本文件
在Python中,處理文本文件是最基礎(chǔ)的文件操作,我們使用內(nèi)置的open函數(shù)打開一個(gè)文件,然后使用文件對象的read或write方法進(jìn)行讀寫操作。
# 寫入文本文件
with open('example.txt', 'w') as f:
f.write('Hello, Python!')
# 讀取文本文件
with open('example.txt', 'r') as f:
print(f.read())
?
在這里,open函數(shù)的第一個(gè)參數(shù)是文件名,第二個(gè)參數(shù)是文件模式,其中'r'代表讀模式,'w'代表寫模式。使用'with'語句可以確保文件在操作完成后被正確關(guān)閉。這是一個(gè)標(biāo)準(zhǔ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ù)分別返回一個(gè)寫入器和讀取器對象,我們可以使用這些對象進(jìn)行CSV文件的讀寫操作。
?
3. JSON文件
JSON(JavaScript Object Notation)是一種輕量級的數(shù)據(jù)交換格式,易于閱讀和編寫,同時(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)是一種標(biāo)記語言,可以用來描述數(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)建一個(gè)XML文件的樹形結(jié)構(gòu),然后使用ElementTree對象的write方法將其寫入文件。讀取XML一個(gè)ElementTree對象,然后通過遍歷這個(gè)對象來讀取XML數(shù)據(jù)。
?
5.二進(jìn)制文件
二進(jìn)制文件是直接包含二進(jìn)制數(shù)據(jù)的文件,例如圖像文件、音頻文件等。Python使用'b'模式打開二進(jìn)制文件,然后使用文件對象的read或write方法進(jìn)行讀寫操作。
# 寫入二進(jìn)制文件
data = b'Hello, Python!'
with open('example.bin', 'wb') as f:
f.write(data)
# 讀取二進(jìn)制文件
with open('example.bin', 'rb') as f:
data = f.read()
print(data)
?
在這里,'wb'和'rb'分別代表二進(jìn)制寫模式和二進(jìn)制讀模式。注意我們使用bytes類型的數(shù)據(jù)進(jìn)行二進(jìn)制寫操作。
?
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庫,這是一個(gè)創(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)建一個(gè)Document對象,然后使用add_paragraph方法添加段落,最后使用save方法保存文檔。讀取Word文件時(shí),我們遍歷Document對象的paragraphs屬性,打印出每個(gè)段落的文本。
?
8. XLSX文件
處理Excel文件,我們可以使用openpyxl庫,這是一個(gè)讀寫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)建一個(gè)Workbook對象和Worksheet對象,然后使用字典方式訪問單元格并賦值,最后使用save方法保存工作簿。讀取Excel文件時(shí),我們使用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ù)庫全都保存在一個(gè)單獨(dú)的文件中。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)建一個(gè)數(shù)據(jù)庫連接和游標(biāo)對象,然后使用execute方法執(zhí)行SQL語句,最后使用commit方法提交事務(wù)。讀取SQLite數(shù)據(jù)庫時(shí),我們遍歷execute方法的結(jié)果,打印出每一行。
?
?
11. 音頻文件
處理音頻文件,我們可以使用pydub庫,這是一個(gè)處理音頻的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庫,這是一個(gè)用于視頻編輯的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) # 打印標(biāo)題
# 注意:BeautifulSoup不能直接創(chuàng)建HTML文件,但可以修改HTML文件
?
?
在這里,我們使用BeautifulSoup對象解析HTML文件,然后通過標(biāo)簽名訪問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)建一個(gè)ZIP文件,然后使用write方法添加文件。讀取ZIP文件時(shí),我們使用namelist方法列出所有文件。
?
One More Thing
在處理文件時(shí),一個(gè)常被忽視但又極其有用的技巧是使用Python的pathlib模塊來處理文件路徑。pathlib模塊提供了一種面向?qū)ο蟮姆绞絹硖幚砦募湍夸浡窂?,使得路徑的處理變得更加直觀和簡潔。?
from pathlib import Path
# 創(chuàng)建Path對象
p = Path('example.txt')
# 檢查文件是否存在
if p.exists():
print('File exists.')
# 獲取文件的后綴名
print(p.suffix)
?
?
在這個(gè)例子中,我們使用Path對象表示一個(gè)文件路徑,然后使用Path對象的方法和屬性來進(jìn)行各種操作,例如檢查文件是否存在,獲取文件的后綴名等。這是一個(gè)非常強(qiáng)大且易用的模塊,可以極大地提高我們處理文件路徑的效率。
?
以上就是Python全文件格式輸入輸出的介紹。希望通過本文,你能夠?qū)ython的文件操作有更深入的理解,并能夠在實(shí)際編程中靈活運(yùn)用。如果你有任何問題或想法,歡迎在評論區(qū)留言分享。文章來源地址http://www.zghlxwxcb.cn/news/detail-449034.html
到了這里,關(guān)于< Python全景系列-4 > 史上最全文件類型讀寫庫大盤點(diǎn)!什么?還包括音頻、視頻?的文章就介紹完了。如果您還想了解更多內(nèi)容,請?jiān)谟疑辖撬阉鱐OY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!