汇总报表
import xlrd,xlsxwriter # 读取 opwb=xlrd.open_workbook('7月下旬入库表.xlsx') opws=opwb.sheet_by_index(0) # opws=opwb.sheet_by_index('七月') tswb=xlsxwriter.Workbook("7月下旬入库表2.xls") tsws=tswb.add_worksheet('7月') # 按行遍历复制 for i in range(opws.nrows): tsws.write_row('A'+str(i),opws.row_values(i-1)) # 关闭并保存创建的表格 tswb.close()
最小读取表格
import xlrd xlsx=xlrd.open_workbook('c:/s.xls') table=xlsx.sheet_by_index(0) print(table.cell_value(3,2)
最小创建表格
import xlsxwriter as xlw test_workbook=xlw.Workbook("test2.xlsx") worksheet=test_workbook.add_worksheet('test_table') worksheet.write(0,'test') test_workbook.close()
按行遍历复制(不带格式)
from xlutils.copy import copy import xlrd,xlsxwriter xlsx=xlrd.open_workbook('7月下旬入库表.xlsx') table=xlsx.sheet_by_index(0) test_workbook=xlsxwriter.Workbook("7月下旬入库表2.xls") worksheet=test_workbook.add_worksheet('7月下旬入库表') for i in range(table.nrows): worksheet.write_row('A'+str(i),table.row_values(i-1)) test_workbook.close()
xlutils带格式复制
from xlutils.copy import copy import xlrd xlsx=xlrd.open_workbook("7月下旬入库表.xls",formatting_info=True) test_sheet=xlsx.sheet_by_index(0) new_excel=copy(xlsx) new_sheet=new_excel.get_sheet(0) new_excel.save('copy.xlsx')
xlsxwriter带格式复制
import xlrd,xlsxwriter # 读取 opwb=xlrd.open_workbook('7月下旬入库表.xlsx') opws=opwb.sheet_by_index(0) # opws=opwb.sheet_by_index('七月') # 创建,新版本xlsxwrite支持创建xls、xlsx tswb=xlsxwriter.Workbook("7月下旬入库表3.xls") tsws=tswb.add_worksheet('7月') bolds = tswb.add_format({'bold': True}) dates = tswb.add_format({'num_format': 'yyyy/m/d'}) tsws.write_column('A1',opws.col_values(0),dates) tsws.write_column('B1',opws.col_values(1)) tsws.write_column('C1',opws.col_values(2)) tsws.write_column('D1',opws.col_values(3)) tsws.write_column('E1',opws.col_values(4),bolds) # 关闭并保存创建的表格 tswb.close()
python处理word
from docx import Document from docx.enum.text import WD_ALIGN_ParaGRAPH from docx.shared import Pt # 磅数 from docx.oxml.ns import qn # 中文格式 # 以上是docx库中需要用到的部分 import time price = input('请输入今日价格:') company_list = ['客户1','客户2','客户3','客户4','客户5','客户6','客户7','客户8','客户9','客户10'] today = time.strftime("%Y{y}%m{m}%d{d}",time.localtime()).format(y='年',m='月',d='日') # 获取今日时间,整理成“年-月-日”的格式 for i in company_list: # 针对每个客户名生成不同文档 document = Document() document.styles['normal'].font.name = u'宋体' # 设置文档的基础字体 document.styles['normal']._element.rPr.rFonts.set(qn('w:eastAsia'),u'宋体') # 设置文档的基础样式 p1 = document.add_paragraph() # 初始化建立第一个自然段 p1.alignment = WD_ALIGN_ParaGRAPH.CENTER # 对齐方式为居中,没有这句的话默认左对齐。 run1 = p1.add_run('关于下达%s产品价格的通知' % (today)) # 这里是第一段的内容 run1.font.name = '微软雅黑' # 设置西文字体 run1._element.rPr.rFonts.set(qn('w:eastAsia'),u'微软雅黑') # 设置中文字体 run1.font.size = Pt(21) # 设置字体大小为21磅 run1.font.bold = True # 设置加粗 p1.space_after = Pt(5) # 段后距离5磅 p1.space_before = Pt(5) # 段前距离5磅 p2 = document.add_paragraph() run2 = p2.add_run(i + ':') # 这里是对客户的称呼 run2.font.name = '仿宋_GB2312' run2._element.rPr.rFonts.set(qn('w:eastAsia'),u'仿宋_GB2312') run2.font.size = Pt(16) run2.font.bold = True p3 = document.add_paragraph() run3 = p3.add_run(' 根据公司安排,为提供优质客户服务,我单位拟定了今日价格为%s元,特此通知。' % price) run3.font.name = '仿宋_GB2312' run3._element.rPr.rFonts.set(qn('w:eastAsia'),u'仿宋_GB2312') run3.font.size = Pt(16) run3.font.bold = True p4 = document.add_paragraph() p4.alignment = WD_ALIGN_ParaGRAPH.CENTER run4 = p4.add_run('(联系人:小杨 电话:18888888888)') run4.font.name = '仿宋_GB2312' run4._element.rPr.rFonts.set(qn('w:eastAsia'),u'仿宋_GB2312') run4.font.size = Pt(16) run4.font.bold = True document.save('%s-价格通知.docx' % i) # 以“客户名-价格通知”作为文件名保存
参考:
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。