首頁 > 後端開發 > Python教學 > 如何用python開啟excel

如何用python開啟excel

silencement
發布: 2019-06-24 10:53:02
原創
24707 人瀏覽過

如何用python開啟excel

最近看到好幾次群組裡有人問xlwt、wlrd的問題,怎麼說呢,如果是office2007剛出來,大家用xlsx檔用不習慣,還可以理解,這都10年過去了餵,就算沒有進化到office2016,還在用office2003的有點說不過去吧。有人可以用xlsx存為xls! ——故意多做幾步操作,目的呢?為了相容?相容古老的office2003?而且,既然都用python來操作excel了,還要手動保存一遍文件,這是神馬思路?

所以,我還是覺得,應該放棄xls而轉型xlsx。所以才有了這篇文章-xlwt、wlrd只能讀寫xls文件,而不能操作xlsx檔。

解決方案:openpyxl。這是一個非常簡單的函式庫,有幾分鐘就能上手了。安裝非常簡單,pip install openpyxl一步搞定,我主要來說說對excel的操作。當然,前面廢話那麼多,同學們差不多也能猜到了吧,openpyxl只能操作xlsx檔而不能操作xls檔。

1、基本概念

在openpyxl中,主要用到三個概念:Workbooks,Sheets,Cells。 Workbook就是一個excel工作表;Sheet是工作表中的一張表頁;Cell就是簡單的一個格。 openpyxl就是圍繞著這三個概念進行的,不管讀寫都是「三板斧」:打開Workbook,定位Sheet,操作Cell。下面分讀和寫分別介紹幾個常見的方法。

2、讀取xlsx

為了做實驗,我事先準備好了一個excel文檔,裡面有Sheet1,Sheet2,Sheet3這三個頁,在Sheet3中填入瞭如下內容:

首先用

from openpyxl import load_workbook
登入後複製

引入庫

wb = load_workbook("template.xlsx")
登入後複製

開啟一個xlsx文件

print(wb.sheetnames)    # ['Sheet1', 'Sheet2', 'Sheet3']
登入後複製

可以看看開啟的Excel裡有哪些sheet頁

sheet = wb.get_sheet_by_name("Sheet3")
登入後複製

讀取到指定的Sheet頁,sheet就變得神奇了,想要的內容都在這裡。例如:

print(sheet["C"])    # (<Cell Sheet3.C1>, <Cell Sheet3.C2>, <Cell Sheet3.C3>, <Cell Sheet3.C4>, <Cell Sheet3.C5>, <Cell Sheet3.C6>, <Cell Sheet3.C7>, <Cell Sheet3.C8>, <Cell Sheet3.C9>, <Cell Sheet3.C10>)      <-第C列
print(sheet["4"])    # (<Cell Sheet3.A4>, <Cell Sheet3.B4>, <Cell Sheet3.C4>, <Cell Sheet3.D4>, <Cell Sheet3.E4>)     <-第4行
print(sheet["C4"].value)    # c4     <-第C4格的值
print(sheet.max_row)    # 10     <-最大行数
print(sheet.max_column)    # 5     <-最大列数
for i in sheet["C"]:
  print(i.value, end=" ")    # c1 c2 c3 c4 c5 c6 c7 c8 c9 c10     <-C列中的所有值
登入後複製

寫入xlsx

#先用

from openpyxl import Workbook
wb = Workbook()
登入後複製

建立一個工作表,然後

sheet = wb.active
登入後複製

找到活動的sheet頁。空的excel表預設的sheet頁就叫Sheet,如果想改名字,可以直接給title屬性賦值。

sheet.title = "New Shit"
登入後複製

這個屬性是可讀可寫的。當然,這個只針對目前活動頁,別的頁的話,可以用create_sheet和remove_sheet進行新增和刪除。

往sheet頁裡面寫內容就比較簡單了,跟上面讀一樣,

sheet[&#39;C3&#39;] = &#39;Hello world!&#39;
for i in range(10):
  sheet["A%d" % (i+1)].value = i + 1
登入後複製

我們還可以進行花式操作,比如寫寫公式:

sheet["E1"].value = "=SUM(A:A)"
登入後複製

最後記得儲存

wb.save(&#39;保存一个新的excel.xlsx&#39;)
登入後複製

以上是如何用python開啟excel的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板