python调用excel的书_Python利用openpyxl处理Excel文件(单元格样式设置)

前面几个章节,简单介绍了openpyxl模块及使用该模块对Excel文件进行简单操作,并通过一个实战项目(人口数据统计)展示了使用openpyxl模块处理Excel文件的优势。今天,我们主要梳理通过openpyxl如何对Excel文件的单元格样式进行编辑。也许有人要问对于Excel文件中的单元格直接利用鼠标键盘进行编辑设置是很方便的,为什么要使用openpyxl进行设置呢?试想,如果Excel文件足够大,比如几M或者更大,某些低配电脑打开这些大文件都是很不方便的(大部分办公电脑配置都不高哦),别提利用鼠标对个别单元格样式进行设置了,查找就很不方便的……这次我们利用上节课实战中得到的人口统计表对表格中的样式进行设置,看看使用openpyxl设置单元格样式的方便之处。

一、单元格样式简介

openpyxl处理Excel文件中单元格样式,总共有六个属性类。分别是:font(字体类,可设置字号、字体颜色、下划线等)、fill(填充类,可设置单元格填充颜色等)、border(边框类,可以设置单元格各种类型的边框)、alignment(位置类、可以设置单元格内数据各种对齐方式)、number_format(格式类,可以设置单元格内各种类型的数据格式)、protection(保护类,可以设置单元格写保护等)。

二、单元格样式设置实例

我们使用官方文档的例子进行梳理。

(一)基本用法

>>>fromopenpyxl.stylesimportPatternFill, Border, Side, Alignment, Protection, Font

>>>font = Font(name='Calibri',

...size=11,

...bold=False,

...italic=False,

...vertAlign=None,

...underline='none',

...strike=False,

...color='FF000000')

>>>fill = PatternFill(fill_type=None,

...start_color='FFFFFFFF',

...end_color='FF000000')

>>>border = Border(left=Side(border_style=None,

...color='FF000000'),

...right=Side(border_style=None,

...color='FF000000'),

...top=Side(border_style=None,

...color='FF000000'),

...bottom=Side(border_style=None,

...color='FF000000'),

...diagonal=Side(border_style=None,

...color='FF000000'),

...diagonal_direction=0,

...outline=Side(border_style=None,

...color='FF000000'),

...vertical=Side(border_style=None,

...color='FF000000'),

...horizontal=Side(border_style=None,

...color='FF000000')

...)

>>>alignment=Alignment(horizontal='general',

...vertical='bottom',

...text_rotation=0,

...wrap_text=False,

...shrink_to_fit=False,

...indent=0)

>>>number_format = 'General'

>>>protection = Protection(locked=True,

...hidden=False)

上述官网介绍的几种属性,通过字面意思很容易了解样式的具体设置,但是,需要强调的是以上几种样式(字体、填充、边框、位置、格式和保护)实例一旦被创建,实例的属性是不可修改的,要想修改属性,只能重新定义一种新的样式实例。

如:fill = PatternFill(fill_type=None,

... start_color='FFFFFFFF',

... end_color='FF000000')

如果你想将fill的start_color和end_color的颜色值互换,使用fill.end_color='FFFFFFFF';fill.start_color='FF000000'是不可以的,只能重新定义一个fill实例。

(二)样式可以被复制

>>> from openpyxl.styles import Font

>>> from copy import copy

>>> ft1 = Font(name='Arial', size=14)

>>> ft2 = copy(ft1)

>>> ft2.name = "Tahoma"

>>> ft1.name

>>> ft2.name

'Tahoma'

>>> ft2.size

14.0

3b87e950352ac65c3777af0c2a30de1592138aa2.jpeg?token=f9db2dd9ea49b9771db18b7e8064e77d&s=8CC2E512110A754902DD80DA000080B3copy执行效果

(三)定义字体颜色

字体颜色既可以使用颜色常量,也可以按照索引创建颜色实例。

>>> from openpyxl.styles import Font

>>> from openpyxl.styles.colors import RED

>>> font = Font(color=RED)

>>> font = Font(color="FFBB00")

>>> from openpyxl.styles.colors import Color

>>> c = Color(indexed=32)

>>> c = Color(theme=6, tint=0.5)

55e736d12f2eb9380b77fa8007a0e931e4dd6ff5.jpeg?token=664116ca7bc27f9b2dce0e5cc907ddcf&s=C442F41A19DF41C80ED401DA000090B1color属性

(四)如何应用样式

可以直接应用到具体单元格,还可以整行整列应用样式,但整行整列应用时单元格必须是已经创建好的单元格。

>>> from openpyxl.workbook import Workbook

>>> from openpyxl.styles import Font, Fill

>>> wb = Workbook()

>>> ws = wb.active

>>> c = ws['A1']

>>> c.font = Font(size=12)

>>> col = ws.column_dimensions['A']

>>> col.font = Font(bold=True)

>>> row = ws.row_dimensions[1]

>>> row.font = Font(underline="single")

(五)如何设置合并单元格的样式

合并单元格的行为与其他单元格项目类似。其值和格式在其左上角的单元格中定义。要更改整个合并单元格的边框,请更改其左上角单元格的边框。格式化是为写入而生成的。

>>> from openpyxl.styles import Border, Side, PatternFill, Font, GradientFill, Alignment

>>> from openpyxl import Workbook

>>> wb = Workbook()

>>> ws = wb.active

>>> ws.merge_cells('B2:F4')

>>> top_left_cell = ws['B2']

>>> top_left_cell.value = "My Cell"

>>> thin = Side(border_style="thin", color="000000")

>>> double = Side(border_style="double", color="ff0000")

>>> top_left_cell.border = Border(top=double, left=thin, right=thin, bottom=double)

>>> top_left_cell.fill = PatternFill("solid", fgColor="DDDDDD")

>>> top_left_cell.fill = fill = GradientFill(stop=("000000", "FFFFFF"))

>>> top_left_cell.font = Font(b=True, color="FF0000")

>>> top_left_cell.alignment = Alignment(horizontal="center", vertical="center")

>>> wb.save("styled.xlsx")

7acb0a46f21fbe096e6bf579baa260378644ade8.jpeg?token=2953f3f5c60ee0dc46d71f968b1b1a7a&s=6902EF1A1B9E45C800D4D1DE010010B3单元格合并后设置样式效果

三、综合实例

将上节课中的“population.xlsx”中的样式进行设置,样式如下:

6c224f4a20a4462314f6702e4ae01e0a0df3d781.jpeg?token=852d3309e009211e2cbac832ecc2faa9&s=4942DC121DDF60CA0A5411CA00008033未设置样式的表格

除标题行外有内容的单元格居中显示,加边框;

(1)标题行A1:D1合并居中,更改标题为“20XX年X国人口统计表”,设置宋体加粗居中,大小24,颜色默认;

(2)行标题字体’黑体’,大小16,红色,加粗显示,背景色蓝色

(3)正文字体’宋体’,大小14,蓝色,不加粗,背景色黄色。

不赘述,直接上代码:

import openpyxl

from openpyxl.styles import PatternFill,

Border, Side, Alignment, Font

from openpyxl.styles.colors import RED,

YELLOW, BLUE, BLACK

alignment=Alignment(horizontal='center',

vertical='center')

thin = Side(border_style="thin",

color=BLACK)

border = Border(top=thin, left=thin, right=thin, bottom=thin)

row_title_font = Font(name='黑体', size=16, bold=True, color=RED)

row_title_fill = PatternFill(fill_type='solid',fgColor=BLUE)

content_font = Font(name='宋体', size=14, bold=False,color=BLUE)

content_fill = PatternFill(fill_type='solid',fgColor=YELLOW)

title_font = Font(name="宋体", bold=True, size=24)

# 打开并编辑

wb = openpyxl.load_workbook("population.xlsx")

ws = wb.get_sheet_by_name("20XX年X国人口统计")

# 标题合并居中

ws.merge_cells("A1:D1")

top_left_cell = ws['A1']

top_left_cell.value = "20XX年X国人口统计表"

top_left_cell.font = title_font

for row in ws.rows:

for cell in row:

cell.alignment = alignment

if cell.row == 1:

continue

elif cell.row == 2:

cell.border = border

cell.font = row_title_font

cell.fill = row_title_fill

else:

cell.border = border

cell.font = content_font

cell.fill = content_fill

# 保存结果

wb.save("population.xlsx")

8326cffc1e178a824125872327c11f89a877e864.jpeg?token=4b1aa48bdd71928c1d4b77d1d6fbaa0c&s=4BAF2F8E0E0E54C84A6FF26F0300507C程序执行后效果图

程序运行后,Excel表格变成了这个样子,可以发挥自己的想象自定义样式,整个表格样式处理时间1分钟左右,别诟病这个时间,要知道这个表格大小是2M多,有7万多条数据的。

四、程序展望

虽然处理样式在openpyxl处理Excel的过程中是个“鸡肋”功能。但是,如果有一天老板让你把几万行数据样式都处理的漂亮一点(亲身经历),当你面对这几万行数据的时候,你就会后悔当初没多学一点……所以,书到用时方恨少,能多学就多学点吧!

样式处理只要记住style的6个大类,程序应用中提前定义好样式内容,然后在cell中赋予响应的样式内容即可,处理过程非常简单,多练习就会融会贯通!

用程序处理样式应用场景自己总结主要有两个地方:一是数据量非常庞大时;二是对大数据表格间断的某几行进行格式化定制时。这两个场景使用openpyxl处理会达到事半功倍的效果。

d50735fae6cd7b8972e8b48cdee62ea3d8330e04.jpeg?token=73c9049d23e2172b8e444692a090e15a&s=29D5AA4ECD73A48E68093F390300D054可爱的python

未完待续

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值