重慶分公司,新征程啟航
為企業提供網站建設、域名注冊、服務器等服務
為企業提供網站建設、域名注冊、服務器等服務
怎么在Python3中利用openpyxl讀寫Excel文件?相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。
Python中常用的操作Excel的三方包有xlrd,xlwt和openpyxl等,xlrd支持讀取.xls和.xlsx格式的Excel文件,只支持讀取,不支持寫入。xlwt只支持寫入.xls格式的文件,不支持讀取。
openpyxl不支持.xls格式,但是支持.xlsx格式的讀取寫入,并且支持寫入公式等。
原始數據文件apis.xlsx內容:
name | method | url | data | json | result |
---|---|---|---|---|---|
get接口 | get | /tupian/20230522/get Kevin,age:1} | |||
post-json接口 | post | https://httpbin.org/post | {name: Kevin,age: 21} |
import openpyxl # 打開excel excel = openpyxl.load_workbook('apis.xlsx') # 有路徑應帶上路徑 # 使用指定工作表 sheet = excel.active # 當前激活的工作表 # sheet = excel.get_sheet_by_name('Sheet1') # 讀取所有數據 print(list(sheet.values)) # sheet.values 生成器 print(sheet.max_column) # 較大列數 print(sheet.max_row) # 較大行數
顯示結果:
[('name', 'method', 'url', 'headers', 'data', 'json', 'result'), ('get接口', 'get', '/tupian/20230522/get None, None, None, None), ('post表單接口', 'post', 'https://httpbin.org/post', 'cookie: token=123', '{name: Kevin,age: 21}', None, None), ('post-json接口', 'post', 'https://httpbin.org/post', None, None, '{name: Kevin,age: 21}', None)]
7
4
代碼接上例
... # 按行讀取 for row in sheet.iter_rows(min_row=1, min_col=1, max_col=3, max_row=3): print(row) # 讀取標題行 for row in sheet.iter_rows(max_row=1): title_row = [cell.value for cell in row] print(title_row) # 讀取標題行以外數據 for row in sheet.iter_rows(min_row=2): row_data = [cell.value for cell in row] print(row_data)
打印結果:
(
, | , | ) |
(, | , | ) |
(, | , | ) |
['name', 'method', 'url', 'headers', 'data', 'json', 'result']
['get接口', 'get', '/tupian/20230522/get None, None, None, None]
['post表單接口', 'post', 'https://httpbin.org/post', 'cookie: token=123', '{name: Kevin,age: 21}', None, None]
['post-json接口', 'post', 'https://httpbin.org/post', None, None, '{name: Kevin,age: 21}', None]
代碼接上例
... # 讀取單元格數據 print(sheet['A1'].value) print(sheet.cell(1,1).value) # 索引從1開始
打印結果:
name
name
代碼接上例
# 寫入單元格 sheet['F2'] = 'PASS' result_col = title_row.index('result')+1 # 'result'所在的列號 sheet.cell(3, result_col).value = 'PASS' # 整行寫入 new_row = ['post-xml接口', 'post', 'https://httpbin.org/post'] sheet.append(new_row) # 保存文件,也可覆蓋原文件 excel.save("apis2.xlsx")
寫入結果:
name | method | url | data | json | result |
---|---|---|---|---|---|
get接口 | get | /tupian/20230522/get Kevin,age:1} | PASS | ||
post-json接口 | post | https://httpbin.org/post | {name: Kevin,age: 21} | ||
post-xml接口 | post | https://httpbin.org/post |
看完上述內容,你們掌握怎么在Python3中利用openpyxl讀寫Excel文件的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注創新互聯行業資訊頻道,感謝各位的閱讀!