python利用xlsxwriter编辑excel表格

#!/usr/bin/env python
# encoding: utf-8

"""
@author: Miss C
@file: demo2.py
@time: 2021/03/17 9:09
@desc:
"""

import xlsxwriter
from datetime import datetime


class BaseExcel(object):
    def __init__(self, table_name, sheet_name):
        # self.out = BytesIO()  # 实例化二进制数据
        self.workbook = xlsxwriter.Workbook(table_name)  # 创建excel实例
        self.table_name = table_name
        self.sheet_name = sheet_name
        self.worksheet = self.workbook.add_worksheet(sheet_name)  # 工作表的名称
        self.worksheet.set_default_row(13.5)  # 设置工作表的行高
        self.worksheet.hide_gridlines(2)  # 隐藏网格线

    def excel_style(self, **kwargs):
        # 编辑单元格样式
        base_style = {
   
            'bold': kwargs.get('bold', False),  # 加粗
            'font_name': kwargs.get('font_name', 'SimSun'),  # 字体类型,默认宋体
            'font_size': kwargs.get('font_size', 10),  # 字体大小,默认12
            'font_color': kwargs.get('font_color', '#000000'),  # 字体颜色,黑色
            'align': kwargs.get('align', 'center'),  # 默认水平居中
            'valign': kwargs.get('valign', 'vcenter'),  # 默认垂直居中
            'text_wrap'
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 你好!对于你的问题,可以使用xlsxwriter中的set_column函数来设置列宽自适应。具体的代码如下: ``` python import xlsxwriter # 新建一个Excel文件 workbook = xlsxwriter.Workbook('demo.xlsx') worksheet = workbook.add_worksheet() # 写入数据 data = [['姓名', '年龄', '籍贯'], ['张三', 20, '北京市海淀区'], ['李四', 18, '江苏省南京市'], ['王五', 22, '河南省郑州市']] for row, row_data in enumerate(data): for col, cell_data in enumerate(row_data): worksheet.write(row, col, cell_data) # 设置列宽自适应 for i, val in enumerate(data[0]): worksheet.set_column(i, i, len(val) + 1) # 关闭Excel文件 workbook.close() ``` 上面的代码中,首先新建一个Excel文件,然后写入数据,接着使用循环将每一列的宽度设置为该列数据最长的字符串的长度加1。最后保存并关闭Excel文件即可。 希望我的回答能够帮到你,如果还有其他问题,欢迎继续咨询我! ### 回答2: 在Python中使用xlsxwriter库创建Excel表格时,可以通过设置worksheet对象的set_column方法来使表格自动适应列宽。 首先,需要导入xlsxwriter库,并创建一个Workbook对象和一个Worksheet对象: ```python import xlsxwriter workbook = xlsxwriter.Workbook('output.xlsx') worksheet = workbook.add_worksheet() ``` 然后,使用write方法将数据写入表格中: ```python worksheet.write('A1', 'Hello') worksheet.write('B1', 'World') ``` 接下来,使用set_column方法设置列宽。该方法接受两个参数,第一个参数是列的索引或列的起始和结束位置,第二个参数是列的宽度。 如果要使所有列的宽度自动适应内容,可以使用set_column方法设置所有列的宽度为None: ```python worksheet.set_column(0, xlsxwriter.consts.MAX_COLUMN, None) ``` 其中,MAX_COLUMN是xlsxwriter库中定义的常量,示最大列索引。 如果只想使特定列的宽度自动适应内容,可以通过set_column方法设置该列的宽度为None: ```python worksheet.set_column('A:A', None) ``` 这样,指定的列就会根据内容自动调整宽度。 最后,使用workbook对象的close方法保存并关闭Excel文件: ```python workbook.close() ``` 以上就是使用Python中的xlsxwriter库使表格自动适应列宽的方法。通过设置worksheet对象的set_column方法,可以实现根据内容自动调整列宽的效果。 ### 回答3: 使用python中的xlsxwriter模块可以很方便地调整表格的列宽,使其自动适应内容的宽度。 首先,需要创建一个Workbook对象,并添加一个工作。例如,可以使用以下代码创建一个名为"Sheet1"的工作: ```python import xlsxwriter # 创建一个Workbook对象 workbook = xlsxwriter.Workbook('output.xlsx') # 添加一个Sheet1工作 worksheet = workbook.add_worksheet('Sheet1') ``` 接下来,需要定义内容并将其写入工作。例如,可以使用以下代码将一些数据写入工作中: ```python # 写入数据 worksheet.write(0, 0, '姓名') worksheet.write(0, 1, '年龄') worksheet.write(1, 0, '张三') worksheet.write(1, 1, 25) worksheet.write(2, 0, '李四') worksheet.write(2, 1, 30) ``` 接下来,可以使用`worksheet.set_column()`方法来调整列的宽度。通过传递列的索引、起始列和结束列的索引以及列的宽度参数,可以设置特定列或一系列列的宽度。例如,以下代码将第一列和第二列的宽度都调整为10: ```python # 设置第一列和第二列的宽度为10 worksheet.set_column(0, 1, 10) ``` 如果想要自动调整列宽以适应内容,可以使用`worksheet.autofilter()`方法。以下代码演示了如何自动调整列宽以适应内容: ```python # 自动调整列宽以适应内容 worksheet.autofilter(0, 0, len(data), len(data[0])-1) ``` 在这个例子中,`data`是一个包含数据的列,`len(data)`是列的行数,`len(data[0])`是列的列数。 最后,使用`workbook.close()`方法保存并关闭工作簿: ```python # 保存并关闭工作簿 workbook.close() ``` 通过上述步骤,可以使用xlsxwriter模块很容易地使表格自动适应列宽。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值