Python开发之Python3读写Excel⽂件(较全)Python3读写Excel⽂件
1、Python中⼏种常⽤包⽐较
2、⽤xlrd包读取Excel⽂件
2.1、⽤法
2.1.1、引⽤包
import xlrd
2.1.2、打开⽂件
xlrd.open_workbook(r'/root/excel/chat.xls')
2.1.3、获取你要打开的sheet⽂件
# 获取所有sheet
sheet_name = workbook.sheet_names()[0]
# 根据sheet索引或者名称获取sheet内容
sheet = workbook.sheet_by_index(0)# sheet索引从0开始
2.1.4、获取指定单元格⾥⾯的值
2.1.5、获取某⾏或者某列的值
# 获取整⾏和整列的值(数组)
rows = w_values(1)# 获取第2⾏内容
cols = l_values(2)# 获取第3列内容
2.1.6、获取sheet的名称,⾏数,列数
# sheet的名称,⾏数,列数
print(sheet.ls)
2.2、源码⽰例
import xlrd
from datetime import date,datetime
arrayNum =6
#array = {'L1':'','L2':'','L3':'','L4':'','Question':'','Answer':''} tables =[]
newTables =[]
def read_excel():
# 打开⽂件
workbook = xlrd.open_workbook(r'/root/chat.xls')
# 获取所有sheet
sheet_name = workbook.sheet_names()[0]
# 根据sheet索引或者名称获取sheet内容
sheet = workbook.sheet_by_index(0)# sheet索引从0开始# sheet = workbook.sheet_by_name('Sheet1')
#print (workboot.sheets()[0])
# sheet的名称,⾏数,列数
print(sheet.ls)
# 获取整⾏和整列的值(数组)
rows = w_values(1)# 获取第2⾏内容
# cols = l_values(2) # 获取第3列内容
print(rows)
# print (cols)
for rown in ws):
array ={'L1':'','L2':'','L3':'','L4':'','Question':'','Answer':''} array['L1']= ll_value(rown,0)
array['L2']= ll_value(rown,1)
array['L3']= ll_value(rown,2)
array['L4']= ll_value(rown,3)
array['Question']= ll_value(rown,4)
array['Answer']= ll_value(rown,5)
tables.append(array)
print(len(tables))
#print (tables)
#print (tables[5])
if __name__ =='__main__':
# 读取Excel
read_excel();
print('读取成功')
3、尽量不⽤xlwt包写⼊Excel⽂件3.1、原因
在xlwt中⽣成的xls⽂件最多能⽀持65536⾏数据。
3.2、如果写⼊过多,会报错
由于数据太多,会报这个错误:
ValueError: row index (65536)not an intin range(65536)错误
3.3、源码⽰例
# 1. 导⼊模块
import xlwt
def write_excel():
# 2. 创建Excel⼯作薄
myWorkbook = xlwt.Workbook()
# 3. 添加Excel⼯作表
mySheet = myWorkbook.add_sheet('A Test Sheet')
# 4. 写⼊数据
myStyle = xlwt.easyxf('font: name Times New Roman, color-index red, bold on', num_format_str='#,##0.00')#数据格式 mySheet.write(i, j,1234.56, myStyle)
mySheet.write(2,0,1)#写⼊A3,数值等于1
mySheet.write(2,1,1)#写⼊B3,数值等于1
mySheet.write(2,2, xlwt.Formula("A3+B3"))#写⼊C3,数值等于2(A3+B3)
#5. 保存
myWorkbook.save('excelFile.xls')
if __name__ =='__main__':
# 写⼊Excel
write_excel();
print('写⼊成功')
4、⽤openpyxl包写⼊Excel⽂件
4.1、⽤法
4.1.1、引⽤包
import openpyxl
4.1.2、创建⼯作簿
f = openpyxl.Workbook()#创建⼯作簿
4.1.3、创建sheet
sheet1 = f.create_sheet()
4.1.4、设置每个单元格⾥⾯的值
for jkey in range(len(newTables)):
jk =1
for cT in range(arrayNum):
jk = jkey +1
if cT ==0:
else:
4.1.5、保存⽂件
f.save("chatPy.xlsx")#保存⽂件
4.2、源码⽰例
f = openpyxl.Workbook()#创建⼯作簿
sheet1 = f.create_sheet()
#sheet1 = f.add_sheet(u'sheet1',cell_overwrite_ok=True) #创建sheet
row0 =[u'L1',u'L2',u'L3',u'L4',u'问题',u'答案']
#⽣成第⼀⾏
#for i in range(len(row0)):
# ll(column=i,row=0).value='L1')
#⽣成后续
for jkey in range(len(newTables)):
jk =1
for cT in range(arrayNum):
jk = jkey +1
if cT ==0:
else:
python怎么读入excel
f.save("chatPy.xlsx")#保存⽂件
if __name__ =='__main__':
# 写⼊Excel
write_excel();
print('写⼊成功')
5、⽤xlsxwriter包写⼊Excel⽂件
5.1、简介
于是我到了xlsxwriter这个模块,它⽣成的⽂件后缀名为.xlsx,最⼤能够⽀持1048576⾏数据,16384列数据5.2、⽤法
5.2.1、引⽤包
import xlsxwriter
5.2.2、创建⼯作簿
workbook = xlsxwriter.Workbook('demo1.xlsx')#创建⼀个excel⽂件
5.2.3、创建sheet
worksheet = workbook.add_worksheet(u'sheet1')#在⽂件中创建⼀个名为TEST的sheet,不加名字默认为sheet1
5.2.4、设置每个单元格⾥⾯的值
worksheet.write(3,0,35.5)#第4⾏的第1列设置值为35.5
5.2.5、关闭⼯作簿
workbook.close()
5.3、源码⽰例
workbook = xlsxwriter.Workbook('chat.xlsx')#创建⼀个excel⽂件
worksheet = workbook.add_worksheet(u'sheet1')#在⽂件中创建⼀个名为TEST的sheet,不加名字默认为sheet1 worksheet.set_column('A:A',20)#设置第⼀列宽度为20像素
bold= workbook.add_format({'bold':True})#设置⼀个加粗的格式对象
worksheet.write('A1','HELLO')#在A1单元格写上HELLO
worksheet.write('A2','WORLD',bold)#在A2上写上WORLD,并且设置为加粗
worksheet.write('B2',U'中⽂测试',bold)#在B2上写上中⽂加粗
worksheet.write(2,0,32)#使⽤⾏列的⽅式写上数字32,35,5
worksheet.write(3,0,35.5)#使⽤⾏列的时候第⼀⾏起始为0,所以2,0代表着第三⾏的第⼀列,等价于A4
worksheet.write(4,0,'=SUM(A3:A4)')#写上excel公式
workbook.close()
if __name__ =='__main__':
# 写⼊Excel
write_excel();
print('写⼊成功')
6、Github源码分享
如果觉得写得不错,帮忙给 github的这个项⽬ 点个star呗
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论