Python文件操作:将txt文件中的数据写入Excel表格

任务:
从两个txt文件中分别读取《Python程序设计》的选择题和判断题,将两种题型以两个Excel工作簿的形式存储于Excel题库文档中。
文本文件内容截图:在这里插入图片描述
运行环境:Python 3.7.2
所需第三方库:openpyxl
运行结果:
在这里插入图片描述
源代码

#调用库函数
from openpyxl import Workbook,load_workbook
from openpyxl.styles import Font,colors#利用这些可以自行设置字体和颜色

#文本读取函数
def readTxt(file):
    ls=list()
    with open(file,'r',encoding='utf-8-sig') as f:
        for line in f.readlines():
            #异常处理机制
            try:
                index1=line.index('、')
                index2=line.index('(')
                number=line[:index1]
                question=line[index1+1:index2]
                answer=line[index2::]#利用切片准确截取主体信息
                ls.append((number,question,answer))#以元组的形式追加进空列表
            except:
                print('wrong format!')
    #返回一个列表
    return ls

#题目写入函数
def write_excel_xlsx1(path, sheet_name, value):
    index = len(value)#列表中所含元组的个数,从而确定写入Excel的行数
    #打开Excel
    wb=load_workbook(path)
    #创建工作簿
    sheet=wb.create_sheet(sheet_name)
    #设置格式
    sheet.column_dimensions['B'].width=115
    #按行加入
    for i in range(index):
        sheet.append(value[i])
    #保存文件
    wb.save(path)
    print("题目写入数据成功!")
 
 #主函数
if__name__=='__main__':
    book_name_xlsx =  r'C:\Users\jl\Desktop\《Python程序设计》题库.xlsx'#文件路径,根据自己的需要自行修改
	wb=Workbook()
	wb.save(book_name_xlsx)
	#工作簿名称
	sheet_name_xlsx1 = '判断题'
	sheet_name_xlsx2 = '填空题'
	art1 = readTxt(r'C:\Users\jl\Desktop\《Python程序设计》题库-判断题.txt')#调用读取函数
	art2 = readTxt(r'C:\Users\jl\Desktop\《Python程序设计》题库-填空题.txt')
	#插入表头
	art1.insert(0,('序号','试题','答案'))
	art2.insert(0,('序号','试题','答案'))
	write_excel_xlsx1(book_name_xlsx, sheet_name_xlsx1, art1)#调用写入函数
	write_excel_xlsx1(book_name_xlsx, sheet_name_xlsx2, art2)
  • 9
    点赞
  • 50
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值