Python文件簡單操作及openpyxl操作excel文件詳解
一、文件的操作流程
第一,建立文件對象。
第二,調(diào)用文件方法進行操作。
第三,關(guān)閉文件。
1、打開文件
用python內(nèi)置的open()函數(shù)打開一個文件,創(chuàng)建一個file對象,相關(guān)的方法才可以調(diào)用它進行讀寫。
f = open(file_name [, access_mode])
file_name:文件名,字符串值
access_mode:打開文件的模式,如只讀,寫入,追加等,這個參數(shù)是非強制的,默認文件訪問模式為只讀r。
# 例子 f = open(r'E:\文件目錄\文件的簡單操作.py') f = open('E:\\文件目錄\\文件的簡單操作.txt') f = open('E:/文件目錄/文件的簡單操作.py') f = open('./文件目錄/' + str(file_name), 'w') print("文件名: ", f.name) print("是否已關(guān)閉 : ", f.closed) print("訪問模式 : ", f.mode)
文件的訪問模式如下表所示,'r’讀,'w’覆蓋寫,'a’追加寫。
模式 | 描述 |
---|---|
r | 以只讀方式打開文件。這是默認模式 |
rb | 以二進制格式打開文件用于只讀。這是默認模式 |
r+ | 打開文件用于讀寫 |
rb+ | 以二進制格式打開文件用于讀寫 |
w | 打開文件只用于寫入。若文件存在將其覆蓋,若不存在創(chuàng)建新文件 |
wb | 以二進制格式打開文件只用于寫入。若文件存在將其覆蓋,若不存在創(chuàng)建新文件 |
w+ | 打開文件用于讀寫,若文件存在將其覆蓋,若不存在創(chuàng)建新文件 |
wb+ | 以二進制格式打開文件用于讀寫,若文件存在將其覆蓋,若不存在創(chuàng)建新文件 |
a | 打開文件用于追加。若文件存在新的內(nèi)容會寫入已有內(nèi)容之后,若不存在創(chuàng)建新文件進行寫入 |
ab | 以二進制格式打開文件用于追加。若文件存在新的內(nèi)容會寫入已有內(nèi)容之后,若不存在創(chuàng)建新文件進行寫入 |
a+ | 打開文件用于讀寫。若文件存在,文件打開時會是追加模式,若不存在創(chuàng)建新文件用于讀寫 |
ab+ | 以二進制格式打開文件用于追加。若文件存在,文件打開時會是追加模式,若不存在創(chuàng)建新文件用于讀寫 |
2、文件操作——讀、寫、修改
(1)讀:read()
讀取整篇文章內(nèi)容
# 打開一個文件 f = open("file.txt", "r",encoding='utf8') f_read = f.read() # 通過read()進行讀取 print(f_read) # 關(guān)閉打開的文件 f.close()
讀取指定數(shù)量的字符
read()方法指定需要讀取的字符數(shù)量,無論一個英文字母還是一個漢字都是一個字符。
f_read = f.read(8) # 讀取8個字符
讀取一行內(nèi)容
readline讀取一行代碼,讀取到第一個換行符就停止。
f_read = f.readline() # 讀取一行內(nèi)容。 f_read1 = f.readline() # 再讀取一行內(nèi)容。
把內(nèi)容以列表的形式輸出
readlines會把內(nèi)容以列表的形式輸出。
f_read = f.readlines() # 以列表的形式輸出。
(2)寫:write()
文件操作中的寫有兩種:
w:覆蓋寫
a:追加寫
write()方法可將任何字符串(Python字符串也可以是二進制數(shù)據(jù))寫入一個打開的文件。write()方法不會在字符串的結(jié)尾添加換行符(‘\n’)。
覆蓋寫(w)
對文件的內(nèi)容進行覆蓋寫入
# 打開一個文件 f = open('file.txt','w',encoding='utf8') f_w = f.write('hello world') print(f_w) # 輸出寫入多少字符 # 關(guān)閉打開的文件 f.close()
追加寫(a)
在文件末尾進行文件的追加寫入
# 打開一個文件 f = open('file.txt','a',encoding='utf8') f_w = f.write('python pandas request') print(f_w) # 輸出寫入多少字符 # 關(guān)閉打開的文件 f.close()
寫入可迭代對象(字符串、列表、元祖、字典)
seq = ["文件操作教程 1\n", "文件操作教程 2"] f.writelines(seq)
(3)修改:replace()
f1 = open('file.txt','r',encoding='utf8') # 原文件 f2 = open('file2.txt','w',encoding='utf8') # 新文件 for line in f1: if "hello" in line: line = line.replace("hello","hi python") f2.write(line) # 關(guān)閉文件 f1.close() f2.close()
with語句
當(dāng)with代碼塊執(zhí)行完畢時,會自動關(guān)閉文件釋放內(nèi)存資源,不用特意加f.close(),而且可以同時對多個文件同時操作。
用with語句重寫修改文件中的代碼:
with open('file.txt','r',encoding='utf8') as f1,open('file2.txt','w',encoding='utf8') as f2: for line in f1: if "hello" in line: line = line.replace("hello","hi python") f2.write(line)
3、關(guān)閉文件
file對象的 close()方法刷新緩沖區(qū)里任何還沒寫入的信息,并關(guān)閉文件,這之后便不能再進行寫入。
# 打開一個文件 f = open("file.txt", "w") # 關(guān)閉打開的文件 f.close()
二、openpyxl操作excel文件
在openpyxl里面,一個Excel文件對應(yīng)著一個Workbook對象, 一個Sheet對應(yīng)著一個Worksheet對象,而一個單元格對應(yīng)著一個Cell對象。Workbook()創(chuàng)建空白excel,load_workbook(file_name)加載已存在的excel,save()保存Workbook對象。
1、導(dǎo)入模塊
import openpyxl
2、創(chuàng)建文件
# 創(chuàng)建空白excel wb = openpyxl.Workbook()
3、打開已有excel文件
# 打開已有的xxx.xlsx文件 wb = openpyxl.load_workbook('./文件目錄/' + str(file_name))
4、創(chuàng)建表
sheet0 = wb.create_sheet(title='表1', index=0) sheet1 = wb.create_sheet(title='表2', index=1) sheet2 = wb.create_sheet(title='表3', index=2) sheet3 = wb.create_sheet(title='表4', index=3)
5、操作單元格
# 通過單元格名稱設(shè)置,指定單元格的值 sheet0["A1"]='當(dāng)前時間' sheet0["B1"]="數(shù)據(jù)類型" # 通過行列坐標(biāo)設(shè)置,指定單元格的值 d = sheet0.cell(row=1, column=1, value='當(dāng)前時間') # 設(shè)置單元格寬度 sheet0.column_dimensions['A'].width = 30.0 sheet0.column_dimensions['B'].width = 30.0
6、設(shè)置整行數(shù)據(jù)
time = datetime.datetime.now().strftime('%F %T') # '2022-10-12 20:05:23' #time1 = time.strftime('%a %b %d %H:%M:%S %p %Y', time.localtime(time.time())) # (星期 月 日 時:分:秒 上午/下午 年)'Wed Sep 07 17:43:25 PM 2022' #time = datetime.datetime.now().strftime('%F %T').split(':') # ['2022-09-07 17', '42', '56'] #time_str = time[0] + '-' + time[1] + '-' + time[2] # '2022-09-07 17-42-56' sheet0.append([time, 'int'])
7、保存文件
wb.save('./文件目錄/' + str(file_name))
到此這篇關(guān)于Python文件簡單操作及openpyxl操作excel文件詳解的文章就介紹到這了,更多相關(guān)Python文件操作內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python基于BeautifulSoup和requests實現(xiàn)的爬蟲功能示例
這篇文章主要介紹了Python基于BeautifulSoup和requests實現(xiàn)的爬蟲功能,結(jié)合實例形式分析了Python使用BeautifulSoup和requests庫爬取網(wǎng)站指定信息的相關(guān)操作技巧,需要的朋友可以參考下2019-08-08Python使用BeautifulSoup4修改網(wǎng)頁內(nèi)容的實戰(zhàn)記錄
BeautifulSoup除了可以查找和定位網(wǎng)頁內(nèi)容,還可以修改網(wǎng)頁,下面這篇文章主要給大家介紹了關(guān)于Python使用BeautifulSoup4修改網(wǎng)頁內(nèi)容的相關(guān)資料,需要的朋友可以參考下2022-05-05Python enumerate函數(shù)功能與用法示例
這篇文章主要介紹了Python enumerate函數(shù)功能與用法,結(jié)合實例形式分析了enumerate函數(shù)針對列表、字符串遍歷操作相關(guān)使用技巧,需要的朋友可以參考下2019-03-03python實現(xiàn)發(fā)送form-data數(shù)據(jù)的方法詳解
這篇文章主要介紹了python實現(xiàn)發(fā)送form-data數(shù)據(jù)的方法,結(jié)合實例形式分析了Python發(fā)送form-data數(shù)據(jù)的相關(guān)操作步驟、實現(xiàn)方法與注意事項,需要的朋友可以參考下2019-09-09使用python進行廣告點擊率的預(yù)測的實現(xiàn)
這篇文章主要介紹了使用python進行廣告點擊率的預(yù)測的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-07-07Python map及filter函數(shù)使用方法解析
這篇文章主要介紹了Python map及filter函數(shù)使用方法解析,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-08-08