⑴ python操作excel方法
這里介紹3種Python讀寫Excel的方法,分別是xlrd和xlwt、openpyxl以及pandas,這3種方法都非常簡單,感興趣的朋友可以自己嘗試一下:
xlrd和xlwt
這是最基本的Python讀寫Excel的方式,xlrd專門用於讀取Excel,xlwt專門用於寫入Excel,下面我簡單介紹一下這種方式:
xlrd讀取excel,測試代碼如下,非常簡單,先打開對應的Excel文件,然後定位到某一個sheet,最後再直接讀取行、列、單元格值即可:
xlwt寫入excel,測試代碼如下,新建一個Excel文件,然後添加一個sheet,最後再直接將數據寫入對應單元格即可:
openpyxl
這也是Python一個專門用於讀寫Excel文件的模塊,基本讀寫方式和xlrd、xlwt差不多,使用起來也非常方便,下面我簡單介紹一下這種方式:
讀取Excel,測試代碼如下,打開Excel文件,然後根據name獲取到對應sheet,最後再直接讀取行、列、單元格值即可:
寫入Excel,測試代碼如下,新建一個Excel文件,然後添加一個活動sheet,最後再直接將數據寫入單元格即可:
pandas
這是Python最簡單的讀寫Excel文件的方法,pandas內置了read_excel和to_excel這2個函數,一行代碼即可完成對Excel文件的讀寫,下面我簡單介紹一下這種方式:
讀取Excel,測試代碼如下,非常簡單,read_excel函數直接讀取即可,這里返回的數據類型是DataFrame,可以按行、列、單元格取值:
寫頃則入Excel,測試代碼如下,先構造需要寫入的數據,然後直接利用DataFrame的to_excel函數保存為Excel文件枯擾即可:
至此,我們就介紹完了Python讀寫Excel文件的3種方法。總的來說,這3種方法都非常簡單,只要你有一定的Python基礎,熟悉一下相關代碼和文檔,很快就能掌握的,網上也有相關教程和資料,介紹的非常詳細,感興趣的話,可以搜一下,希望雀敗棚以上分享的內容能對你有所幫助吧,也歡迎大家評論、留言進行補充。
⑵ 如何使用Python來批量處理Excel中單元格的超鏈接
excel自帶的公式或vba比python方便的多,python也還是調用com介面使用這些屬性方法的。
同一文件內部處理,vba更方便。
大量excel文件批量處理,python方便。
你這個需求:
運行這個宏,就自動在A列生成了你要的目錄了,點目錄鏈接自動跳轉到對應的工作表。
⑶ mac上用python導入excel
mac上用python導入excel具體步驟。
1、引用第三方庫:進入python環境路徑下,使用終端進入該路徑。如找不到該路徑,可以直接復制pycharm中的python環境路徑,在finder搜索,會展示該路徑下的文件,右鍵退回上層文件夾,就能找到安裝路徑了。安裝pythonExcel庫中的xlwt/xlrd庫,用於寫入和讀取Excel文件。
2、在指定目錄下創建Excel文件。
3、在Excel中添加行或者列。命令行:sheet.write(行,列,value)。該位置的行與列,以0開始為第一行,第一列,如:sheet.write(0,0,序號),表示在Excel的第一行第一列寫下字元串:序號。
4、讀取Excel中的數據:讀取表格中某一行,某一列的數據。讀取表格中全部數據。
⑷ excel怎麼導入python中
讀excel要用到xlrd模塊,官網安裝(http://pypi.python.org/pypi/xlrd)。然後就可以跟著裡面的例子稍微試一下就知道怎麼用了。大概的流程是這樣的:
1、導入模塊
import xlrd
2、打開Excel文件讀取數據
data = xlrd.open_workbook('excel.xls')
3、獲取一個工作表
① table = data.sheets()[0] #通過索引順序獲取
② table = data.sheet_by_index(0) #通過索引順序獲取
③ table = data.sheet_by_name(u'Sheet1')#通過名稱獲取
4、獲取整行和整列的值(返回數組)
table.row_values(i)
table.col_values(i)
5、獲取行數和列數
table.nrows
table.ncols
6、獲取單元格
table.cell(0,0).value
table.cell(2,3).value
就我自己使用的時候覺得還是獲取cell最有用,這就相當於是給了你一個二維數組,餘下你就可以想怎麼干就怎麼幹了。得益於這個十分好用的庫代碼很是簡潔。但是還是有若干坑的存在導致話了一定時間探索。現在列出來供後人參考吧:
1、首先就是我的統計是根據姓名統計各個表中的信息的,但是調試發現不同的表中各個名字貌似不能夠匹配,開始懷疑過編碼問題,不過後來發現是因為空格。因為在excel中輸入的時候很可能會順手在一些名字後面加上幾個空格或是tab鍵,這樣看起來沒什麼差別,但是程序處理的時候這就是兩個完全不同的串了。我的解決方法是給每個獲取的字元串都加上strip()處理一下。效果良好
2、還是字元串的匹配,在判斷某個單元格中的字元串(中文)是否等於我所給出的的時候發現無法匹配,並且各種unicode也不太奏效,網路過一些解決方案,但是都比較復雜或是沒用。最後我採用了一個比較變通的方式:直接從excel中獲取我想要的值再進行比較,效果是不錯就是通用行不太好,個呢不能問題還沒解決。
二、寫excel表
寫excel表要用到xlwt模塊,官網下載(http://pypi.python.org/pypi/xlwt)。大致使用流程如下:
1、導入模塊
復制代碼代碼如下:
import xlwt
2、創建workbook(其實就是excel,後來保存一下就行)
復制代碼代碼如下:
workbook = xlwt.Workbook(encoding = 'ascii')
3、創建表
復制代碼代碼如下:
worksheet = workbook.add_sheet('My Worksheet')
4、往單元格內寫入內容
復制代碼代碼如下:
worksheet.write(0, 0, label = 'Row 0, Column 0 Value')
5、保存
復制代碼代碼如下:
workbook.save('Excel_Workbook.xls')
⑸ python用xlwt,超鏈接到另一sheet,如何設置HYPERLINK
我這里運行的很好,沒有錯誤提示,打開顯示也正常。
運行環境是:Python 3.50,Excel 2007
importxlwt
book=xlwt.Workbook()
sheet_index=book.add_sheet('index')
line=0
foriinrange(9):
sheet1=book.add_sheet(str(i))
sheet1.write(0,0,str(i))
link='HYPERLINK("#%s";"%s")'%(str(i),str(i))
sheet_index.write(line,0,xlwt.Formula(link))
line+=1
book.save('simple2.xls')