zoukankan      html  css  js  c++  java
  • 【Python工具】Excle 读写 (使用 xlrd 和 xlrt)

    一、安装 xlrd 和xlwt 模块

    直接通过pip安装

    pip install xlrd
    pip install xlwt
    

    二、操作使用

    import xlrd
    #打开excel
    data = xlrd.open_workbook('demo.xls') #注意这里的workbook首字母是小写
    查看文件中包含sheet的名称
    data.sheet_names()
    得到第一个工作表,或者通过索引顺序 或 工作表名称
    table = data.sheets()[0]
    table = data.sheet_by_index(0)
    table = data.sheet_by_name(u'Sheet1')
    获取行数和列数
    nrows = table.nrows
    ncols = table.ncols
    获取整行和整列的值(数组)
    table.row_values(i)
    table.col_values(i)
    循环行,得到索引的列表
    for rownum in range(table.nrows):
    print table.row_values(rownum)
    单元格
    cell_A1 = table.cell(0,0).value
    cell_C4 = table.cell(2,3).value
    分别使用行列索引
    cell_A1 = table.row(0)[0].value
    cell_A2 = table.col(1)[0].value
    简单的写入
    row = 0
    col = 0
    ctype = 1 # 类型 0 empty,1 string, 2 number, 3 date, 4 boolean, 5 error
    value = 'lixiaoluo'
    xf = 0 # 扩展的格式化 (默认是0)
    table.put_cell(row, col, ctype, value, xf)
    table.cell(0,0) # 文本:u'lixiaoluo'
    table.cell(0,0).value # 'lixiaoluo'


    1、在openwork报错Debug错误信息

    #打开excel
    data = xlrd.open_workbook('demo.xls') #注意这里的workbook首字母是小写
    Traceback (most recent call last):
      File "D:/PycharmProject/InvestProject/CleanData/excle_data_filter.py", line 6, in <module>
        data = xlrd.open_workbook(u'invest.xls')
      File "D:Python27libsite-packagesxlrd\__init__.py", line 441, in open_workbook
        ragged_rows=ragged_rows,
      File "D:Python27libsite-packagesxlrdook.py", line 116, in open_workbook_xls
        bk.parse_globals()
      File "D:Python27libsite-packagesxlrdook.py", line 1158, in parse_globals
        self.handle_sst(data)
      File "D:Python27libsite-packagesxlrdook.py", line 1129, in handle_sst
        self._sharedstrings, rt_runlist = unpack_SST_table(strlist, uniquestrings)
      File "D:Python27libsite-packagesxlrdook.py", line 1350, in unpack_SST_table
        nchars = local_unpack('<H', data[pos:pos+2])[0]
    struct.error: unpack requires a string argument of length 2

    解决方法:

    用了个很愚蠢的办法,把excle 用WPS或者MS Excle打开 然后再保存为另外一份就可以了。

    我想我的excle是通过Navicat从Mysql中导出来的,格式不对应吧。

    ###我想修改excle表的内容,可是xlrd是只读,xlrt是只写,好麻烦

    Python中一般使用xlrd(excel read)来读取Excel文件,使用xlwt(excel write)来生成Excel文件(可以控制Excel中单元格的格式),需要注意的是,用xlrd读 取excel是不能对其进行操作的:xlrd.open_workbook()方法返回xlrd.Book类型,是只读的,不能对其进行操作。而 xlwt.Workbook()返回的xlwt.Workbook类型的save(filepath)方法可以保存excel文件。因此对于读取和生成 Excel文件都非常容易处理,但是对于已经存在的Excel文件进行修改就比较麻烦了。不过,还有一个xlutils(依赖于xlrd和xlwt)提供复制excel文件内容和修改文件的功能。其实际也只是在xlrd.Book和xlwt.Workbook之间建立了一个管道而已,如下图:

     

    xlutils.copy模块的copy()方法实现了这个功能,示例代码如下:

    from xlrd import open_workbook
    from xlutils.copy import copy
     
    rb = open_workbook('m:\1.xls') //data
     
    #通过sheet_by_index()获取的sheet没有write()方法
    rs = rb.sheet_by_index(0)//table
     
    wb = copy(rb)
     
    #通过get_sheet()获取的sheet有write()方法
    ws = wb.get_sheet(0)
    ws.write(0, 0, 'changed!')
     
    wb.save('m:\1.xls')
  • 相关阅读:
    AutoFac学习笔记
    AutoMapper学习笔记
    ROSLYN 查看C#方法执行次数
    log4net 动态创建文件名
    WPF可切换按钮,iOS风格
    咕咕咕
    贪吃的小J
    UK Day15
    UK Day15
    UK Day15
  • 原文地址:https://www.cnblogs.com/zzblee/p/5463493.html
Copyright © 2011-2022 走看看