python excel接口_Python的Excel接口 xlrd | 学步园

使用xlrd能够很方便的读取 excel 文件内容, 而且这是个跨平台的库,能够在windows,linux/unix,等平台上面使用。

示例代码:

import xlrd

fname = "sample.xls"

bk = xlrd.open_workbook(fname)

shxrange = range(bk.nsheets)

try:

sh = bk.sheet_by_name("Sheet1")

except:

print "no sheet in %s named Sheet1" % fname

return None

nrows = sh.nrows

ncols = sh.ncols

print "nrows %d, ncols %d" % (nrows,ncols)

cell_value = sh.cell_value(1,1)

print cell_value

row_list = []

for i in range(1,nrows):

row_data = sh.row_values(i)

row_list.append(row_data)

————————————————————————————————————————————————

————————————————————————————————————————————————

sudo easy_install xlrd # windows 参考http://pypi.python.org/pypi/xlrd

sudo easy_install xlwt  # windows 参考http://pypi.python.org/pypi/xlwt

简单使用:

import xlrd

data = xlrd.open_workbook('demo.xls') # 打开demo.xls

data.sheet_names() # 获取xls文件中所有sheet的名称

table = data.sheets()[0] # 获取xls文件第一个工作表

table = data.sheet_by_index(0) # 通过索引获取xls文件第0个sheet

table = data.sheet_by_name(u'Sheet1') # 通过工作表名获取 sheet

# 获取行数和列数

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 = 'liluo'

xf = 0 # 扩展的格式化 (默认是0)

table.put_cell(row, col, ctype, value, xf)

table.cell(0,0) # 文本:u'lixiaoluo'

table.cell(0,0).value # 'lixiaoluo'

简易使用:

import xlwt

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

table = file.add_sheet('sheet name') # 新建一个sheet

table.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') # 保存文件

# 另外,使用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) # 使用样式

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值