python读写excel文件

传说中python操作ms office功能最强大的是win32com,但只能要ms上使用。

不过对于比较简单的需求显得有些小题大作。那么来看下简单的,分别是xlrd和xlwt模块,

不过暂时只支持excel2003 ,但是可以跨平台操作。

xlrd

http://pypi.python.org/pypi/xlrd
导入
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'

xlwt

http://pypi.python.org/pypi/xlrd

导入xlwt

import xlwt

新建一个excel文件

file = xlwt.Workbook() #注意这里的Workbook首字母是大写,无语吧

新建一个sheet

table = file.add_sheet('sheet name')

写入数据table.write(行,列,value)

table.write(0,0,'test')

如果对一个单元格重复操作,会引发

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')

另外,使用style

style = xlwt.XFStyle() # 初始化样式

font = xlwt.Font() #为样式创建字体

font.name = 'Times New Roman'

font.bold = True

style.font = font #为样式设置字体

table.write(0, 0, 'some bold Times text', style) # 使用样式

xlwt 允许单元格或者整行地设置格式。还可以添加链接以及公式。可以阅读源代码,那里有例子:

dates.py, 展示如何设置不同的数据格式

hyperlinks.py, 展示如何创建超链接 (hint: you need to use a formula)

merged.py, 展示如何合并格子

row_styles.py, 展示如何应用Style到整行格子中.

具体的例子可以看:

http://scienceoss.com/write-excel-files-with-python-using-xlwt/

google论坛:

http://groups.google.com/group/python-excel/

三 修改excel 

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')
 
#通过sheet_by_index()获取的sheet没有write()方法
rs = rb.sheet_by_index(0)
 
wb = copy(rb)
 
#通过get_sheet()获取的sheet有write()方法
ws = wb.get_sheet(0)
ws.write(0, 0, 'changed!')
 
wb.save('m:\\1.xls')

 

四 参考 

http://pypi.python.org/pypi/xlrd
http://pypi.python.org/pypi/xlwt
http://pypi.python.org/pypi/xlutils

 

本文整合自 

http://www.leyond.info/write-excel-files-with-python-using-xlwt/
http://www.leyond.info/read-excel-from-python-using-xlrs/

 

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 可以使用 pandas 库中的 read_excel() 函数来读取 Excel 文件,示例代码如下: ```python import pandas as pd # 读取 Excel 文件 df = pd.read_excel('example.xlsx', sheet_name='Sheet1') # 打印读取的数据 print(df) ``` 其中,'example.xlsx' 是 Excel 文件的路径,'Sheet1' 是要读取的工作表名称。read_excel() 函数还有很多参数可以设置,具体可以参考 pandas 文档。 ### 回答2: Python读取Excel文件可以使用第三方库如`pandas`和`openpyxl`。下面以`pandas`为例介绍如何读取Excel文件。 1. 安装pandas库:在命令行中运行`pip install pandas`命令,安装最新版本的pandas库。 2. 导入pandas库:在Python代码中导入pandas库,`import pandas as pd`。 3. 使用pandas读取Excel文件:使用`pd.read_excel()`函数来读取Excel文件。例如,如果要读取名为`data.xlsx`的Excel文件,可以使用以下代码: ```python data = pd.read_excel('data.xlsx') ``` 这将把Excel文件中的数据读取到一个名为`data`的DataFrame对象中。 4. 处理Excel数据:读取Excel文件后,可以对数据进行各种操作,如筛选、排序、计算等。例如,可以使用`head()`函数查看前几行数据: ```python print(data.head()) ``` 5. 保存结果:如果需要将处理后的数据保存为Excel文件,可以使用`to_excel()`函数。例如,将处理后的数据保存为名为`result.xlsx`的文件: ```python data.to_excel('result.xlsx', index=False) ``` 这将生成一个不包含索引的Excel文件。 总结:使用`pandas`库的`read_excel()`函数可以方便地读取Excel文件,然后可以对数据进行各种处理和保存。通过这些简单的步骤,我们可以轻松地在Python中读取和处理Excel文件。 ### 回答3: Python读取Excel文件的主要方式是使用第三方库:openpyxl和pandas。 使用openpyxl库可以实现对Excel文件的读取和写入操作。首先,我们需要安装openpyxl库。然后,导入openpyxl模块,使用`load_workbook`函数加载Excel文件,再选择指定的工作表。接着,我们可以通过读取单元格的值、行或列的数据等方式来获取Excel文件中的数据。 另一个常用的库是pandas,它提供了更高级的Excel文件读取和处理功能。首先,我们需要安装pandas库。然后,导入pandas模块,使用`read_excel`函数来读取Excel文件。这个函数可以直接读取整个Excel文件或选择指定的工作表。我们可以通过DataFrame数据结构或`values`属性来获取Excel文件中的数据。 无论使用openpyxl还是pandas,读取Excel文件的过程中,我们需要注意文件路径的正确设置,并确保Excel文件格式正确。 总的来说,Python读取Excel文件的过程需要依托openpyxl或pandas等库来实现。通过这些库,我们可以方便地读取Excel文件中的数据,并进行后续的处理和分析。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值