前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >学习Python与Excel:使用xlwt在没有Excel的情况下编写电子表格

学习Python与Excel:使用xlwt在没有Excel的情况下编写电子表格

作者头像
fanjy
发布2023-02-24 20:52:40
1.7K0
发布2023-02-24 20:52:40
举报
文章被收录于专栏:完美Excel

标签:Python与Excel,xlwt

有时候,不需要调用Excel来处理电子表格数据。例如,使用xlwt。

首先,使用pip命令在终端安装xlwt:

pip install xlwt

下面是一个示例。原始的文本文件数据如下:

09700RESEARCH

09800PHYSICIANS PRIVATE OFFICES

09900NONPAID WORKERS

MANAGEMENT FEES

REFERENCE LABS

原始数据被搅和在一起,账号和类别没有分开,有些数据甚至没有账号。将这些数据写入Excel工作表并格式化,如下图1所示。

图1

要创建这样的输出,代码脚本执行以下操作:

1.分隔帐号和名称

2.分配一个99999的帐号,并将未编号帐号的单元格颜色设置为红色

3.将帐户名转换为正确的大写名称

4.删除帐户名中的任何多余空格

5.将账号和姓名写入电子表格中的两列

6.根据最宽数据的宽度设置每个电子表格列的列宽格式

代码如下:

代码语言:javascript
复制
import sys
import re
from xlwt import Workbook, easyxf
def dox1():
 try:
   fp = open(r"C:\test\hospdata.txt")
 except:
   print('打开hospdata.txt失败')
   sys.exit(1)
   lines = fp.readlines()
   nameandnum = re.compile(r'(\d+)\s*(.*)\s*')
   wb = Workbook()
   wsraw = wb.add_sheet('Raw Data')
   ws = wb.add_sheet('Account List')
   ws.write(0, 0, 'Account Number')
   ws.write(0, 1, 'Account Name')
   ws.col(0).width = len('Account Number') * 256
   ws.col(1).width = max([len(line) for line in lines]) * 256
   r = 1

   for line in lines:
     wsraw.write(r, 0, line.strip())
     m = nameandnum.match(line)
     if m:
         ws.write(r, 0, int(m.group(1)))
         ws.write(r, 1, ' '.join([w.capitalize() for w in m.group(2).split()]))
     else:
         ws.write(r, 0, 99999, easyxf('pattern: pattern solid, fore_colour red;'))
         ws.write(r, 1, ' '.join([w.capitalize() for w in line.split()]))
     r += 1
   wb.save(r'C:\test\accounts.xls')
   print('已写入accounts.xls')

if __name__ == "__main__":
 dox1()

注:本文学习整理自pythonexcels.com,供参考。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2023-01-12,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 完美Excel 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
访问管理
访问管理(Cloud Access Management,CAM)可以帮助您安全、便捷地管理对腾讯云服务和资源的访问。您可以使用CAM创建子用户、用户组和角色,并通过策略控制其访问范围。CAM支持用户和角色SSO能力,您可以根据具体管理场景针对性设置企业内用户和腾讯云的互通能力。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档