使用Python和xlwt向Excel檔案中寫入中文
下面要為大家分享一篇使用Python和xlwt向Excel檔案中寫入中文的實例,具有很好的參考價值,希望對大家有幫助。一起來看看吧
Python等工具確實是不錯的工具,但有時候不管是基礎的Python還是Python的軟體包都讓我覺得對中文不是很親近。時不時遇到一點問題很正常,剛剛在寫Excel檔案的時候就又遇到這樣的問題了。
為了能夠說明情況,假設我想把目前資料夾中所有的檔案名稱全都寫入到Excel檔案中。
目前的目錄資訊如下:
grey@DESKTOP-3T80NPQ:/mnt/e/01_workspace/01_docs/02_blog/2017年/08月$ ls -l total 1464 -rwxrwxrwx 1 rootroot 13067 Aug 20 18:58 as86汇编程序的编译与链接.docx -rwxrwxrwx 1 rootroot 13794 Aug 8 22:07 C语言中access函数的使用.docx -rwxrwxrwx 1 rootroot 13285 Aug 8 23:08 C语言中合并字符串.docx -rwxrwxrwx 1 rootroot 15514 Aug 8 23:28 C语言中的动态内存分配.docx -rwxrwxrwx 1 rootroot 13765 Aug 8 23:43 GNU glibc中对C语言标准库中动态内存管理的改进.docx -rwxrwxrwx 1 rootroot 14450 Aug 8 22:37 GNU glibc库中函数执行成功与失败的返回值.docx -rwxrwxrwx 1 rootroot 13485 Aug 20 14:51 Linux 0.12的任务调度猜测.docx -rwxrwxrwx 1 rootroot 11934 Aug 20 13:20 Linux BIOS启动.docx -rwxrwxrwx 1 rootroot 13349 Aug 20 19:38 Linux中dd命令的使用.docx -rwxrwxrwx 1 rootroot 13802 Aug 20 19:20 Linux中使用dd命令修改as86汇编编译链接后的程序.docx -rwxrwxrwx 1 rootroot 15118 Aug 20 16:47 Linux启动代码boot.s理解.docx -rwxrwxrwx 1 rootroot 16005 Aug 20 14:25 Linux操作系统的BIOS启动流程.docx -rwxrwxrwx 1 rootroot 14755 Aug 20 01:29 Linux的proc文件系统.docx -rwxrwxrwx 1 rootroot 12777 Aug 1 23:50 mot文件的单行校验与全局校验.docx -rwxrwxrwx 1 rootroot 131404 Aug 13 14:50 Office 2016 Excel实现下拉栏.docx -rwxrwxrwx 1 rootroot 86665 Aug 19 11:44 Office 2016中修改正文默认字体.docx -rwxrwxrwx 1 rootroot 113476 Aug 9 21:07 PPT中修改已插入对象的图标.docx -rwxrwxrwx 1 rootroot 13636 Aug 16 22:23 Python2与Python3中__bool__方法的差异.docx -rwxrwxrwx 1 rootroot 13924 Aug 1 23:32 Python2与Python3中除法功能的异同.docx -rwxrwxrwx 1 rootroot 14551 Aug 16 23:09 Python2与Python3在不同类的对象比较上的差异.docx -rwxrwxrwx 1 rootroot 14101 Aug 12 10:30 Python abc模块的几个小知识点.docx -rwxrwxrwx 1 rootroot 13581 Aug 9 23:24 Python OOP容器设计时合理引入列表方法.docx -rwxrwxrwx 1 rootroot 12890 Aug 12 14:29 Python中isinstance用法.docx -rwxrwxrwx 1 rootroot 13899 Aug 9 22:46 Python中list的extend方法.docx -rwxrwxrwx 1 rootroot 13142 Aug 18 02:22 Python中__new__方法的使用.docx -rwxrwxrwx 1 rootroot 13280 Aug 20 23:17 Python中使用property实现类的特性.docx -rwxrwxrwx 1 rootroot 13257 Aug 16 22:39 Python中定制类的比较运算方法.docx -rwxrwxrwx 1 rootroot 13897 Aug 18 22:45 Python中最基础类的属性和信息.docx -rwxrwxrwx 1 rootroot 13567 Aug 19 11:53 Python中的@classmethod用法.docx -rwxrwxrwx 1 rootroot 14859 Aug 12 15:32 Python中的join函数用法.docx -rwxrwxrwx 1 rootroot 13832 Aug 18 01:38 Python中的weakref简单小结.docx -rwxrwxrwx 1 rootroot 13314 Aug 16 20:51 Python中的哈希常识小结.docx -rwxrwxrwx 1 rootroot 13822 Aug 12 19:15 Python中的静态函数用法.docx -rwxrwxrwx 1 rootroot 15223 Aug 11 00:12 Python中@符号的用法-1.docx -rwxrwxrwx 1 rootroot 162 Aug 21 23:20 ~$Python和xlwt向Excel文件中写入中文.docx -rwxrwxrwx 1 rootroot 13519 Aug 10 20:01 Python实现接受任意个数参数的函数.docx -rwxrwxrwx 1 rootroot 15114 Aug 19 20:31 Python实现更相减损术求解最大公约数.docx -rwxrwxrwx 1 rootroot 13425 Aug 10 22:51 Python编程中NotImplementedError的使用.docx -rwxrwxrwx 1 rootroot 13345 Aug 20 22:27 Python通过属性手段实现只允许调用一次的方法.docx -rwxrwxrwx 1 rootroot 13586 Aug 19 11:15 Python面向对象编程中属性的基本操作.docx -rwxrwxrwx 1 rootroot 139264 Aug 2 23:50 Simulink解析带有系数和偏移量的CAN报文信息.docx -rwxrwxrwx 1 rootroot 13542 Aug 19 17:22 TAOCP中1.1习题1解答与思考.docx -rwxrwxrwx 1 rootroot 13683 Aug 19 16:05 TAOCP中最大公约数算法理解.docx -rwxrwxrwx 1 rootroot 13539 Aug 20 18:41 Ubuntu上安装as86汇编器.docx -rwxrwxrwx 1 rootroot 203890 Aug 12 14:20 Windows10安装bash.docx -rwxrwxrwx 1 rootroot 258 Aug 21 23:19 xlwt_demo.py -rwxrwxrwx 1 rootroot 13353 Aug 18 02:07 使用__del__方法在Python文件处理时保证文件关闭.docx -rwxrwxrwx 1 rootroot 127142 Aug 7 21:07 使用PolySpace进行模型的检测.docx -rwxrwxrwx 1 rootroot 12430 Aug 21 23:22 使用Python和xlwt向Excel文件中写入中文.docx -rwxrwxrwx 1 rootroot 13303 Aug 19 19:06 辗转相除法求最大公约数.docx
其中,xlwt_demo.py是提前編寫Python腳本,程式碼如下:
##!/usr/bin/python # -*- coding-cp936-*- import os import xlwt from xlwt importWorkbook book = Workbook() sheet1 =book.add_sheet('list') row_num = 0 for f inos.listdir('.'): sheet1.write(row_num,0,f) row_num += 1 book.save('demo.xls')
##程式執行結果:
grey@DESKTOP-3T80NPQ:/mnt/e/01_workspace/01_docs/02_blog/2017年/08月$ python xlwt_demo.py Traceback (mostrecent call last): File "xlwt_demo.py", line 14, in<module> book.save('demo.xls') File"/usr/local/lib/python2.7/dist-packages/xlwt/Workbook.py", line 710,in save doc.save(filename_or_stream,self.get_biff_data()) File"/usr/local/lib/python2.7/dist-packages/xlwt/Workbook.py", line 674,in get_biff_data shared_str_table = self.__sst_rec() File"/usr/local/lib/python2.7/dist-packages/xlwt/Workbook.py", line 636,in __sst_rec return self.__sst.get_biff_record() File"/usr/local/lib/python2.7/dist-packages/xlwt/BIFFRecords.py", line77, in get_biff_record self._add_to_sst(s) File"/usr/local/lib/python2.7/dist-packages/xlwt/BIFFRecords.py", line92, in _add_to_sst u_str = upack2(s, self.encoding) File"/usr/local/lib/python2.7/dist-packages/xlwt/UnicodeUtils.py", line50, in upack2 us = unicode(s, encoding) UnicodeDecodeError:'ascii' codec can't decode byte 0xe6 in position 4: ordinal not in range(128)
經過檢視文檔,修改程式碼如下:
#!/usr/bin/python # -*- coding:cp936 -*- import os import xlwt from xlwt importWorkbook book =Workbook(encoding='utf-8') sheet1 =book.add_sheet('list') row_num = 0 for f inos.listdir('.'): sheet1.write(row_num,0,f) row_num += 1 book.save('demo.xls')
程式執行結果如下:
grey@DESKTOP-3T80NPQ:/mnt/e/01_workspace/01_docs/02_blog/2017年/08月$ python xlwt_demo.pygrey@DESKTOP-3T80NPQ:/mnt/e/pygrey@DESKTOP-3T80NPQ:/mnt/e/pygrey@DESKTOP-3T80NPQ:/mnt/e/pygrey@DESKTOP-3T80NPQ:/mnt/e/pygrey@DESKTOP-3T80NPQ:/mnt/e/pygrey@DESKTOP-3T80NPQ:/mnt/e/pNPQ 01_workspace/01_docs/02_blog/2017年/08月$ lsas86組合程式的編譯與連結.docx Python中使用property實作類別的特性.docx#C語言中access函數的使用.docx Python中自訂類別的比較運算方法.docxC語言中合併字串.docx Python中最基礎類別的屬性和資訊.docx##C語言中的動態內存分配.docx Python中的@classmethod用法.docx
##demo.xls Python中的join函數用法.docxGNU glibc中對C語言標準庫中動態記憶體管理的改進.docx Python中的weakref簡單小結.docxGNU glibc函式庫中函數執行成功與失敗的回傳值.docx Python中的雜湊常識小結.docxLinux 0.12的任務排程猜測. docx Python中的靜態函數用法.docxLinux BIOS啟動.docx Python中@符號的用法-1.docxLinux中dd指令的使用.docx ~$Python和xlwt向Excel檔案中寫入中文.docxLinux中使用dd指令修改as86彙編編譯連結後的程式.docx Python實作接受任一數參數的函數.docxLinux啟動程式碼boot .s理解.docx Python實作更相減損術求解最大公約數.docxLinux作業系統的BIOS啟動流程.docx Python程式設計中NotImplementedError的使用.docxLinux的proc檔系統.docx Python透過屬性手段實作只允許呼叫一次的方法.docxmot檔案的單行校驗與全域校驗.docx Python物件導向程式設計中屬性的基本操作.docx #Office 2016 Excel實作下拉欄.docx Simulink解析帶有係數和偏移量的CAN報文資訊.docxOffice 2016中修改正文預設字體.docx TAOCP中1.1習題1解答與思考.docx PPT中修改已插入物件的圖示.docx TAOCP中最大公約數演算法理解.docxPython2與Python3中__bool__方法的差異.docx Ubuntu上安裝as86彙編器. docxPython2與Python3中除法功能的異同.docx Windows10安裝bash.docxPython2與Python3在不同類別的物件比較上的差異.docx xlxl_demo.py##wt#Python abc模組的幾個小知識點.docx 使用__del__方法在Python文件處理時保證文件關閉.docx
Python OOP容器設計時合理引入列表方法.docx 使用PolySpace進行模型的檢測.docx
Python中isinstance用法.docx 使用Python和xlwt向Excel檔案中寫入中文.docxPython中list的extend方法.docx 輾轉相除法求最大公約數.docx Python中__new__方法的使用.docx
值得注意的是,在Windows下編碼cp936是可以寫入成功的,但是在Linux中只能夠用utf-8。這是個很有意思的現象,目前我還沒能夠想明白。
相關推薦:如何在python環境下操作excel
###### ###########
以上是使用Python和xlwt向Excel檔案中寫入中文的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

PHP主要是過程式編程,但也支持面向對象編程(OOP);Python支持多種範式,包括OOP、函數式和過程式編程。 PHP適合web開發,Python適用於多種應用,如數據分析和機器學習。

PHP適合網頁開發和快速原型開發,Python適用於數據科學和機器學習。 1.PHP用於動態網頁開發,語法簡單,適合快速開發。 2.Python語法簡潔,適用於多領域,庫生態系統強大。

Python更適合初學者,學習曲線平緩,語法簡潔;JavaScript適合前端開發,學習曲線較陡,語法靈活。 1.Python語法直觀,適用於數據科學和後端開發。 2.JavaScript靈活,廣泛用於前端和服務器端編程。

PHP起源於1994年,由RasmusLerdorf開發,最初用於跟踪網站訪問者,逐漸演變為服務器端腳本語言,廣泛應用於網頁開發。 Python由GuidovanRossum於1980年代末開發,1991年首次發布,強調代碼可讀性和簡潔性,適用於科學計算、數據分析等領域。

VS Code可以在Windows 8上運行,但體驗可能不佳。首先確保系統已更新到最新補丁,然後下載與系統架構匹配的VS Code安裝包,按照提示安裝。安裝後,注意某些擴展程序可能與Windows 8不兼容,需要尋找替代擴展或在虛擬機中使用更新的Windows系統。安裝必要的擴展,檢查是否正常工作。儘管VS Code在Windows 8上可行,但建議升級到更新的Windows系統以獲得更好的開發體驗和安全保障。

VS Code 可用於編寫 Python,並提供許多功能,使其成為開發 Python 應用程序的理想工具。它允許用戶:安裝 Python 擴展,以獲得代碼補全、語法高亮和調試等功能。使用調試器逐步跟踪代碼,查找和修復錯誤。集成 Git,進行版本控制。使用代碼格式化工具,保持代碼一致性。使用 Linting 工具,提前發現潛在問題。

在 Notepad 中運行 Python 代碼需要安裝 Python 可執行文件和 NppExec 插件。安裝 Python 並為其添加 PATH 後,在 NppExec 插件中配置命令為“python”、參數為“{CURRENT_DIRECTORY}{FILE_NAME}”,即可在 Notepad 中通過快捷鍵“F6”運行 Python 代碼。

在 Sublime Text 中運行 Python 代碼,需先安裝 Python 插件,再創建 .py 文件並編寫代碼,最後按 Ctrl B 運行代碼,輸出會在控制台中顯示。
