DDR爱好者之家 Design By 杰米
一、创建excel代码
备注:封装好了(可直接调用)
""" -*- coding:utf-8 -*- @Time :2020/8/20 21:02 @Author :Jarvis @File :jar_excel_util.py @Version:1.0 """ from typing import List import xlwt class JarExcelUtil: def __init__(self, header_list: List[list]): """ :param header_list: 如下格式 例1:默认列宽 header_list = [ ['序号'], # 表格第0列[此列表头名称] ['姓名'], ['性别'], ['爱好'], ['生日'] ] 例2:自定义列宽(列宽值为int类型 英文字符长度 如:10 表示列宽为10个英文字符长度) header = [ ['序号', 5], # 表格第0列[此列表头名称,列宽] ['姓名', 10], # 表格第1列[此列表头名称,列宽] ['性别', 10], ['爱好', 10], ['生日', 20] ] """ self.data = header_list self.__color_str = 'aqua 0x31\r\nblack 0x08\r\nblue 0x0C\r\nblue_gray 0x36\r\nbright_green 0x0B\r\nbrown 0x3C\r\ncoral 0x1D\r\ncyan_ega 0x0F\r\ndark_blue 0x12\r\ndark_blue_ega 0x12\r\ndark_green 0x3A\r\ndark_green_ega 0x11\r\ndark_purple 0x1C\r\ndark_red 0x10\r\ndark_red_ega 0x10\r\ndark_teal 0x38\r\ndark_yellow 0x13\r\ngold 0x33\r\ngray_ega 0x17\r\ngray25 0x16\r\ngray40 0x37\r\ngray50 0x17\r\ngray80 0x3F\r\ngreen 0x11\r\nice_blue 0x1F\r\nindigo 0x3E\r\nivory 0x1A\r\nlavender 0x2E\r\nlight_blue 0x30\r\nlight_green 0x2A\r\nlight_orange 0x34\r\nlight_turquoise 0x29\r\nlight_yellow 0x2B\r\nlime 0x32\r\nmagenta_ega 0x0E\r\nocean_blue 0x1E\r\nolive_ega 0x13\r\nolive_green 0x3B\r\norange 0x35\r\npale_blue 0x2C\r\nperiwinkle 0x18\r\npink 0x0E\r\nplum 0x3D\r\npurple_ega 0x14\r\nred 0x0A\r\nrose 0x2D\r\nsea_green 0x39\r\nsilver_ega 0x16\r\nsky_blue 0x28\r\ntan 0x2F\r\nteal 0x15\r\nteal_ega 0x15\r\nturquoise 0x0F\r\nviolet 0x14\r\nwhite 0x09\r\nyellow 0x0D' self.color_list = [] # [[]] [['aqua', '0x31'], ['black', '0x08'], ...] for color in self.__color_str.split('\r\n'): color = color.split(' ') self.color_list.append(color) def write(self, out_file, data_body: List[list], sheet_name='sheet', frozen_row: int = 1, frozen_col: int = 0): """ 写入数据 :param out_file: 保存文件(如:test.xlsx) :param data_body: data_body[0]为表格第0行数据 data_body[0][0]为表格第0行第0列单元格值 :param sheet_name: :param frozen_row: 冻结行(默认首行) :param frozen_col: 冻结列(默认不冻结) """ # step1 判断数据正确性(每行列数是否与表头相同) count = 0 for pro in data_body: if len(pro) != len(self.data): raise Exception( 'data_body数据错误 第{}行(从0开始) 需为{}个元素 当前行{}个元素:{}'.format(count, len(self.data), len(pro), str(pro))) count += 1 # step2 写入数据 wd = xlwt.Workbook() sheet = wd.add_sheet(sheet_name) ali_horiz = 'align: horiz center' # 水平居中 ali_vert = 'align: vert center' # 垂直居中 fore_colour = 'pattern: pattern solid,fore_colour pale_blue' # 设置单元格背景色为pale_blue色 # 表头格式(垂直+水平居中、表头背景色) style_header = xlwt.easyxf('{};{};{}'.format(fore_colour, ali_horiz, ali_vert)) # 表体格式(垂直居中) style_body = xlwt.easyxf('{}'.format(ali_vert)) # 表头 for col in self.data: # 默认列宽 if len(col) == 1: sheet.write(0, self.data.index(col), str(col[0]), style_header) # 自定义列宽 if len(col) == 2: sheet.write(0, self.data.index(col), str(col[0]), style_header) # 设置列宽 sheet.col(self.data.index(col)).width = 256 * col[1] # 256为基数 * n个英文字符 # 行高(第0行) sheet.row(0).height_mismatch = True sheet.row(0).height = 20 * 20 # 20为基数 * 20榜 # 表体 index = 1 for pro in data_body: sheet.row(index).height_mismatch = True sheet.row(index).height = 20 * 20 # 20为基数 * 20榜 for d in self.data: value = pro[self.data.index(d)] # 若值类型是int、float 直接写入 反之 转成字符串写入 if type(value) == int or type(value) == float: sheet.write(index, self.data.index(d), value, style_body) else: sheet.write(index, self.data.index(d), str(value), style_body) index += 1 # 冻结(列与行) sheet.set_panes_frozen('1') sheet.set_horz_split_pos(frozen_row) # 冻结前n行 sheet.set_vert_split_pos(frozen_col) # 冻结前n列 wd.save(out_file) def color_test(self): """ 测试颜色 """ body_t = [] for color in self.color_list: print(color) body_t.append(color) wd = xlwt.Workbook() sheet = wd.add_sheet('sheet') index = 0 for b in body_t: ali = 'align: horiz center;align: vert center' # 垂直居中 水平居中 fore_colour = 'pattern: pattern solid,fore_colour {}'.format( self.color_list[index][0]) # 设置单元格背景色为pale_blue色 style_header = xlwt.easyxf( '{};{}'.format(fore_colour, ali)) sheet.write(index, 0, str(b), style_header) sheet.col(0).width = 256 * 150 # 256为基数 * n个英文字符 index += 1 wd.save('颜色测试.xlsx') # 测试颜色 # if __name__ == '__main__': # header_t = [ # ['颜色'] # ] # JarExcelUtil(header_t).color_test() if __name__ == '__main__': header = [ ['序号', 5], ['姓名', 10], ['性别', 10], ['爱好', 10], ['生日', 20] ] # header = [ # ['序号'], # ['姓名'], # ['性别'], # ['爱好'], # ['生日'] # ] body = [ [1, '张三', '男', '篮球', '1994-07-23'], [2, '李四', '女', '足球', '1994-04-03'], [3, '王五', '男', '兵乓球', '1994-09-13'] ] JarExcelUtil(header_list=header).write(out_file='测试.xlsx', data_body=body)
二、效果
生成的Excel
三、常用操作
3.1、设置行高
# 行高(第0行) sheet.row(0).height_mismatch = True sheet.row(0).height = 20 * 20 # 20为基数 * 20榜
3.2、设置列宽
# 列宽(第0列) sheet.col(0).width = 256 * 30 # 256为基数 * 30个英文字符(约)
3.3、冻结(列与行)
# 冻结(列与行) sheet.set_panes_frozen('1') sheet.set_horz_split_pos(2) # 冻结前2行 sheet.set_vert_split_pos(3) # 冻结前3列 # 冻结首行 sheet.set_panes_frozen('1') sheet.set_horz_split_pos(1) # 冻结前1行(即首行)
3.4、设置单元格对齐方式
# 方式1 style_1 = xlwt.XFStyle() al_1 = xlwt.Alignment() al_1.horz = xlwt.Alignment.HORZ_CENTER # 水平居中 al_1.vert = xlwt.Alignment.VERT_CENTER # 垂直居中 style_1.alignment = al_1 sheet.write(0, 0, '第0行第0列单元格值', style_1) # 方式2(推荐) ali_horiz = 'align: horiz center' # 水平居中 ali_vert = 'align: vert center' # 垂直居中 style_2 = xlwt.easyxf('{};{}'.format(ali_horiz, ali_vert)) sheet.write(0, 0, '第0行第0列单元格值', style_2)
3.5、设置单元格背景色
# 设置单元格背景色 fore_colour = 'pattern: pattern solid,fore_colour pale_blue' # 设置单元格背景色为pale_blue色 (具体颜色值 参考上面代码JarExcelUtil类中的color_test方法的运行结果) style = xlwt.easyxf('{}'.format(fore_colour)) sheet.write(0, 0, '第0行第0列单元格值', style)
以上就是Python xlrd/xlwt 创建excel文件及常用操作的详细内容,更多关于python 操作excel的资料请关注其它相关文章!
DDR爱好者之家 Design By 杰米
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
DDR爱好者之家 Design By 杰米
暂无评论...
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新日志
2024年11月24日
2024年11月24日
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]