python xlsxwriter dict_python XlsxWriter围绕多个单元格设置边框

I need an easy way to set border around multiple cells, like so:

All I found was border of 1 cell, and merge cells, which is not what I need.

I was expecting for something like:

worksheet.range_border(first_row, first_col, last_row, last_col)

Is there a way that this can be done (that is not involving setting top_border, bottom_border,

left_border, right_border for each cell individually)?

解决方案

XlsxWriter is an awesome module that made my old job 1,000x easier (thanks John!), but formatting cells with it can be time-consuming. I've got a couple helper functions I use to do stuff like this.

First, you need to be able to create a new format by adding properties to an existing format:

def add_to_format(existing_format, dict_of_properties, workbook):

"""Give a format you want to extend and a dict of the properties you want to

extend it with, and you get them returned in a single format"""

new_dict={}

for key, value in existing_format.__dict__.iteritems():

if (value != 0) and (value != {}) and (value != None):

new_dict[key]=value

del new_dict['escapes']

return(workbook.add_format(dict(new_dict.items() + dict_of_properties.items())))

Now build off of that function with:

def box(workbook, sheet_name, row_start, col_start, row_stop, col_stop):

"""Makes an RxC box. Use integers, not the 'A1' format"""

rows = row_stop - row_start + 1

cols = col_stop - col_start + 1

for x in xrange((rows) * (cols)): # Total number of cells in the rectangle

box_form = workbook.add_format() # The format resets each loop

row = row_start + (x // cols)

column = col_start + (x % cols)

if x < (cols): # If it's on the top row

box_form = add_to_format(box_form, {'top':1}, workbook)

if x >= ((rows * cols) - cols): # If it's on the bottom row

box_form = add_to_format(box_form, {'bottom':1}, workbook)

if x % cols == 0: # If it's on the left column

box_form = add_to_format(box_form, {'left':1}, workbook)

if x % cols == (cols - 1): # If it's on the right column

box_form = add_to_format(box_form, {'right':1}, workbook)

sheet_name.write(row, column, "", box_form)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值