python3 写入excel_Python3 读、写Excel文件的操作方法

首先,简单介绍一下EXECL中工作簿和工作表的区别:

工作簿的英文是BOOK(WORKBOOK),工作表的英文是SHEET(WORKSHEET)。

•一个工作簿就是一个独立的文件

•一个工作簿里面可以有1个或者多个工作表

•工作簿是工作表的集合

1:使用python实现对Excel文件的读写,首先需要安装专用的模块(可以自己编写)xlrd,xlwt模块

2:读取excel数据(注意事项:sheet编号,行号,列号都是从索引0开始)

2018102010551127.png

import xlrd

# 设置路径

path = 'E:/input.xlsx'

# 打开execl

workbook = xlrd.open_workbook(path)

# 输出Excel文件中所有sheet的名字

print(workbook.sheet_names())

# 根据sheet索引或者名称获取sheet内容

Data_sheet = workbook.sheets()[0] # 通过索引获取

# Data_sheet = workbook.sheet_by_index(0) # 通过索引获取

# Data_sheet = workbook.sheet_by_name(u'名称') # 通过名称获取

print(Data_sheet.name) # 获取sheet名称

rowNum = Data_sheet.nrows # sheet行数

colNum = Data_sheet.ncols # sheet列数

# 获取所有单元格的内容

list = []

for i in range(rowNum):

rowlist = []

for j in range(colNum):

rowlist.append(Data_sheet.cell_value(i, j))

list.append(rowlist)

# 输出所有单元格的内容

for i in range(rowNum):

for j in range(colNum):

print(list[i][j], '\t\t', end="")

print()

# 获取整行和整列的值(列表)

rows = Data_sheet.row_values(0) # 获取第一行内容

cols = Data_sheet.col_values(1) # 获取第二列内容

# print (rows)

# print (cols)

# 获取单元格内容

cell_A1 = Data_sheet.cell(0, 0).value

cell_B1 = Data_sheet.row(0)[1].value # 使用行索引

cell_C1 = Data_sheet.cell(0, 2).value

cell_D2 = Data_sheet.col(3)[1].value # 使用列索引

print(cell_A1, cell_B1, cell_C1, cell_D2)

# 获取单元格内容的数据类型

# ctype:0 empty,1 string, 2 number, 3 date, 4 boolean, 5 error

print('cell(0,0)数据类型:', Data_sheet.cell(0, 0).ctype)

print('cell(1,0)数据类型:', Data_sheet.cell(1, 0).ctype)

print('cell(1,1)数据类型:', Data_sheet.cell(1, 1).ctype)

print('cell(1,2)数据类型:', Data_sheet.cell(1, 2).ctype)

# 获取单元格内容为日期的数据

date_value = xlrd.xldate_as_tuple(Data_sheet.cell_value(1,0),workbook.datemode)

print(type(date_value), date_value)

print('%d:%d:%d' % (date_value[0:3]))

3:创建excel并写入数据

2018102010551128.png

import xlwt

def set_style(name, height, bold=False):

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

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

font.name = name

font.bold = bold

font.color_index = 4

font.height = height

style.font = font

return style

def write_excel(path):

# 创建工作簿

workbook = xlwt.Workbook(encoding='utf-8')

# 创建sheet

data_sheet = workbook.add_sheet('demo')

row0 = [u'字段名称', u'大致时段', 'CRNTI', 'CELL-ID']

row1 = [u'测试', '15:50:33-15:52:14', 22706, 4190202]

# 生成第一行和第二行

for i in range(len(row0)):

data_sheet.write(0, i, row0[i], set_style('Times New Roman', 220, True))

data_sheet.write(1, i, row1[i], set_style('Times New Roman', 220, True))

# 保存文件

# workbook.save('demo.xls')

workbook.save(path)

if __name__ == '__main__':

# 设置路径

path = 'E:/demo.xls'

write_excel(path)

print(u'创建demo.xls文件成功')

再看一个例子:

转载:Ryan in C++

基本的write函数接口很简单:

•新建一个excel文件: file = xlwt.Workbook() (注意这里的Workbook首字母是大写)

•新建一个sheet: table = file.add_sheet('sheet_name')

•写入数据table.write(行,列,value): table.write(0,0,'test')

•如果是写入中文,则要用u'汉字'的形式。比如: table.write(0,0, u'汉字')

•合并单元格: table.write_merge(x, x + m, y, y + n, string, style)

•x表示行,y表示列,m表示跨行个数,n表示跨列个数,string表示要写入的单元格内容,style表示单元格样式

"""

设置单元格样式

"""

import xlwt

def set_style(font_name, font_height, bold=False):

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

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

font.name = font_name # 'Times New Roman'

font.bold = bold

font.color_index = 4

font.height = font_height

borders = xlwt.Borders()

borders.left = 6

borders.right = 6

borders.top = 6

borders.bottom = 6

style.font = font

style.borders = borders

return style

# 写excel

def write_excel(output_path):

f = xlwt.Workbook() # 创建工作簿

'''

创建第一个sheet:

sheet1

'''

sheet1 = f.add_sheet(u'sheet1',cell_overwrite_ok=True) # 创建sheet

row0 = [u'业务',u'状态',u'北京',u'上海',u'广州',u'深圳',u'状态小计',u'合计']

column0 = [u'机票',u'船票',u'火车票',u'汽车票',u'其它']

status = [u'预订',u'出票',u'退票',u'业务小计']

# 生成第一行

for i in range(0, len(row0)):

sheet1.write(0, i, row0[i], set_style('Times New Roman', 220, True))

# 生成第一列和最后一列(合并4行)

i, j = 1, 0

while i < 4*len(column0) and j < len(column0):

sheet1.write_merge(i, i+3, 0, 0, column0[j], set_style('Arial', 220, True)) # 第一列

sheet1.write_merge(i, i+3, 7, 7) # 最后一列"合计"

i += 4

j += 1

sheet1.write_merge(21,21,0,1,u'合计',set_style('Times New Roman',220,True))

# 生成第二列

i = 0

while i < 4*len(column0):

for j in range(0,len(status)):

sheet1.write(j+i+1, 1, status[j])

i += 4

f.save(output_path)

if __name__ == '__main__':

write_excel('E:/demo.xls') # 保存文件.这里如果是.xlsx的话会打不开。

注意:如果对一个单元格重复操作,会引发error。所以在打开时加cell_overwrite_ok=True解决

table = file.add_sheet('sheet name',cell_overwrite_ok=True)

生成的demo.xls效果如下:

2018102010551129.png

总结

以上所述是小编给大家介绍的Python3 读、写Excel文件的操作方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
对于计算机专业的学生而言,参加各类比赛能够带来多方面的益处,具体包括但不限于以下几点: 技能提升: 参与比赛促使学生深入学习和掌握计算机领域的专业知识与技能,如编程语言、算法设计、软件工程、网络安全等。 比赛通常涉及实际问题的解决,有助于将理论知识应用于实践中,增强问题解决能力。 实践经验: 大多数比赛都要求参赛者设计并实现解决方案,这提供了宝贵的动手操作机会,有助于积累项目经验。 实践经验对于计算机专业的学生尤为重要,因为雇主往往更青睐有实际项目背景的候选人。 团队合作: 许多比赛鼓励团队协作,这有助于培养学生的团队精神、沟通技巧和领导能力。 团队合作还能促进学生之间的知识共享和思维碰撞,有助于形成更全面的解决方案。 职业发展: 获奖经历可以显著增强简历的吸引力,为求职或继续深造提供有力支持。 某些比赛可能直接与企业合作,提供实习、工作机会或奖学金,为学生的职业生涯打开更多门路。 网络拓展: 比赛是结识同行业人才的好机会,可以帮助学生建立行业联系,这对于未来的职业发展非常重要。 奖金与荣誉: 许多比赛提供奖金或奖品,这不仅能给予学生经济上的奖励,还能增强其成就感和自信心。 荣誉证书或奖状可以证明学生的成就,对个人品牌建设有积极作用。 创新与研究: 参加比赛可以激发学生的创新思维,推动科研项目的开展,有时甚至能促成学术论文的发表。 个人成长: 在准备和参加比赛的过程中,学生将面临压力与挑战,这有助于培养良好的心理素质和抗压能力。 自我挑战和克服困难的经历对个人成长有着深远的影响。 综上所述,参加计算机领域的比赛对于学生来说是一个全面发展的平台,不仅可以提升专业技能,还能增强团队协作、沟通、解决问题的能力,并为未来的职业生涯奠定坚实的基础。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值