• 【python之路28】模块python与excel


    一、可使用的第三方库

    python中处理excel表格,常用的库有xlrd(读excel)表、xlwt(写excel)表、openpyxl(可读写excel表)等。xlrd读数据较大的excel表时效率高于openpyxl,所以我在写脚本时就采用了xlrd和xlwt这两个库。介绍及下载地址为:http://www.python-excel.org/ 这些库文件都没有提供修改现有excel表格内容的功能。一般只能将原excel中的内容读出、做完处理后,再写入一个新的excel文件。

    二、常见问题

    使用python处理excel表格时,发现两个个比较难缠的问题:unicode编码和excel中记录的时间。

    因为python的默认字符编码都为unicode,所以打印从excel中读出的中文或读取中文名的excel表或sheet时,程序提示错误UnicodeEncodeError: 'ascii' codec can't encode characters in position 0-2: ordinal not in range(128)。这是由于在windows中,中文使用了gb2312编码方式,python将其当作unicode和ascii来解码都不正确才报出的错误。使用VAR.encode('gb2312')即可解决打印中文的问题。(很奇怪,有的时候虽然能打印出结果,但显示的不是中文,而是一堆编码。)若要从中文文件名的excel表中读取数据,可在文件名前加‘u’表示将该中文文件名采用unicode编码。

    有excel中,时间和日期都使用浮点数表示。可看到,当‘2013年3月20日’所在单元格使用‘常规’格式表示后,内容变为‘41353’;当其单元格格式改变为日期后,内容又变为了‘2013年3月20日’。而使用xlrd读出excel中的日期和时间后,得到是的一个浮点数。所以当向excel中写入的日期和时间为一个浮点数也不要紧,只需将表格的表示方式改为日期和时间,即可得到正常的表示方式。excel中,用浮点数1表示1899年12月31日。

    三、常用函数

    以下主要介绍xlrd、xlwt、datetime中与日期相关的函数。

    #!usr/bin/env python
    # -*- coding:utf-8 -*-
    #excel的读操作read excel
    import xlrd
    book = xlrd.open_workbook(r'C:UsersSSHDesktop测试.xlsx')  #打开工作薄
    print("worksheet name(s):",book.sheet_names())  #打印工作薄中的所有工作表,['Sheet1', 'Sheet2', 'Sheet3']
    print('book.nsheets',book.nsheets)  #打印工作薄中的工作表数量
    
    sh = book.sheet_by_index(0)  #工作薄中的第一个工作表对象赋值给sh
    print('sh.name:',sh.name,'sh.nrows:',sh.nrows,'sh.ncols:',sh.ncols) #工作表的名字、有数据的行数量、有数据的列数量
    print('A1',sh.cell_value(0,0))  #打印表格A1中的内容
    
    #excel的写操作 write excel
    import xlwt
    book = xlwt.Workbook()   #创建一个空的工作薄
    sheet1 = book.add_sheet('hello') #在工作薄中创建一个名字为hello的工作表
    book.add_sheet('world') #在工作薄中创建一个名字为world的工作表
    sheet1.write(0,0,'单元格a1') #在1行1列写入单元格a1
    row1 = sheet1.row(1)   #sheet1的第2行赋值给row1
    row1.write(0,'a2')  #在sheet1的第2行,1列写入a2
    row1.write(1,'b2')  #在sheet1的第2行,2列写入a2
    
    sheet1.col(0).width = 10000  #调整第1列的列宽为10000
    sheet2 = book.get_sheet(1)   #得到第2个表格的对象赋值给sheet2
    print(sheet2.name)   #表格2的名字
    sheet2.row(0).write(0,'sheet 2 a1')  #在第1行中的第1列写入
    sheet2.row(0).write(1,'sheet 2 b1')
    sheet2.flush_row_data()
    
    sheet2.write(1,0,'sheet 2 a2')
    sheet2.col(0).width = 5000
    sheet2.col(0).hidden = True
    
    book.save('bbb.xls') #保存文件到当前路径,只能保存为.xls,不能保存为.xlsx
  • 相关阅读:
    支付
    mui自定义事件带参返回mui.back()
    tomcat+nginx反向代理(实现一个服务器,一个ip共用80端口)
    mui.back()返回刷新功能
    WiFi(网络)调试Android手机
    mysql获取外键, 根据数据库名和表名获取表所对应的所有外键
    @RequestBody接收json字符串,自动将日期字符串转换为java.util.Date
    使用MySQLWorkBench绘制ER图
    jpa动态分页查找
    displaytag的Excel导出实践
  • 原文地址:https://www.cnblogs.com/sunshuhai/p/6496288.html
Copyright © 2020-2023  润新知