首页 > 代码库 > Python读写Excel

Python读写Excel

  首先是要安装xlrd和xlwt:

  进入xlrd和xlwt压缩包释放后所在的文件夹,并执行命令:C:\xlwt-0.7.4>python  setup.py  install

  会有报错:记住一定是要在xlrd和xlwt所在文件夹下执行,Python的命令改成绝对路径。

  安装之后就可以import xlrd和import xlwt了。

  至于使用,举几个简单的例子:

  

import xlrddata = xlrd.open_workbook(‘demo.xls‘) # 打开demo.xlsdata.sheet_names()        # 获取xls文件中所有sheet的名称table = data.sheets()[0]  # 获取xls文件第一个工作表table = data.sheet_by_index(0)        # 通过索引获取xls文件第0个sheettable = data.sheet_by_name(u‘Sheet1‘) # 通过工作表名获取 sheet# 获取行数和列数nrows = table.nrowsncols = table.ncols# 获取整行和整列的值(数组)table.row_values(i)table.col_values(i)# 循环行,得到索引的列表for rownum in range(1,table.nrows):    print table.row_values(rownum)# 获取单元格cell_A1 = table.cell(0,0).valuecell_C4 = table.cell(2,3).value# 分别使用行列索引cell_A1 = table.row(0)[0].valuecell_A2 = table.col(1)[0].value


import xlwtfile = xlwt.Workbook()                # 注意这里的Workbook首字母是大写table = file.add_sheet(‘sheet name‘)  # 新建一个sheettable.write(0,0,‘test‘)               # 写入数据table.write(行,列,value)# 如果对一个单元格重复操作,会引发# returns error:# Exception: Attempt to overwrite cell:# sheetname=u‘sheet 1‘ rowx=0 colx=0# 所以在打开时加cell_overwrite_ok=True解决table = file.add_sheet(‘sheet name‘,cell_overwrite_ok=True)file.save(‘demo.xls‘)     # 保存文件# 另外,使用stylestyle = xlwt.XFStyle()    # 初始化样式font = xlwt.Font()        # 为样式创建字体font.name = ‘Times New Roman‘font.bold = Truestyle.font = font         #为样式设置字体table.write(0, 0, ‘some bold Times text‘, style) # 使用样式

Tips:

  在使用xlwt3的时候出现了非常奇怪的问题,就是无论如何写都会出现一个奇怪的错误

 
 
Traceback (most recent call last):
  File "F:\temp\mycode\frist\frist.py", line 132, in <module>
    import xlwt3
  File "C:\Python33\lib\site-packages\xlwt3\__init__.py", line 3, in <module>
    from .workbook import Workbook
  File "C:\Python33\lib\site-packages\xlwt3\workbook.py", line 5, in <module>
    from .worksheet import Worksheet
  File "C:\Python33\lib\site-packages\xlwt3\worksheet.py", line 7, in <module>
    from .row import Row
  File "C:\Python33\lib\site-packages\xlwt3\row.py", line 8, in <module>
    from . import formula
  File "C:\Python33\lib\site-packages\xlwt3\formula.py", line 6, in <module>
    class Formula(object):
ValueError: ‘__init__‘ in __slots__ conflicts with class variable
 
代码如下
import xlwt3
wbk=xlwt3.Workbook()
sheet = wbk.add_sheet(‘sheet1‘,True)
sheet.write(2, 0, 1)
sheet.write(2, 1, 1)
wbk.save(‘ccc.xls‘)
 
解决方法:
打开Python33\Lib\site-packages\xlwt3\formula.py文件,将其中的
__slots__ = ["__init__",  "__s", "__parser", "__sheet_refs", "__xcall_refs"]
修改为
__slots__ = [ "__s", "__parser", "__sheet_refs", "__xcall_refs"]
不知道原因。

Python读写Excel