python xlwt模块的使用解析


Posted in Python onApril 13, 2021

一、基础类介绍

1、工作簿类Workbook简介:

import xlwt
class  Workbook(object0):
    '''
    工作簿类,使用xlwt创建excel文件时,首先要实例化此类的对象
    '''
     def __init__(self, encoding='ascii', style_compression=0):
        pass

    def add_sheet(self,sheetname, cell_overwrite_ok=False):
        '''
        在工作簿中创建工作表
        :param sheetname: 工作表的名字
        :param cell_overwrite_ok: 如果值为True,则可以像单元格中多次写入数据(覆盖写),相当于修改单元格的数据,如果值为False则多次写入会引发异常。
        :return: 返回一个工作表对象(也就是Worksheet()对象)
        '''
        pass
    def save(self,filename_or_stream):
        '''
        将文件以Excel的格式进行保存
        :param filename_or_stream:Excel的文件名
        :return:
        '''
        pass

2、工作表类WorkSheet简介

class Worksheet(object):
    '''
    工作表类
    '''
    def __init__(self, sheetname, parent_book, cell_overwrite_ok=False):
        '''
        实例化对象的参数
        :param sheetname: 工作表名
        :param parent_book: 工作簿对象
        :param cell_overwrite_ok:覆盖写单元格(如果为True可以覆盖写单元格,为False如果覆盖写会抛异常)
        '''
        pass

    def write(self, r, c, label="", style=xlwt.Style.default_style):
        '''
        将数据写入工作表的单元格中
        :param r: row的缩写,表示行,从0开始计数。
        :param c: column的缩写,表示列,从0开始计数。
        :param label:要写入的数据(支持的数据类型:int,long,float,字符串,日期,TRUE,FALSE,xlwt.Formula等)
        :param style:表格样式(样式类:Font, Alignment, Borders, Pattern, Protection。样式函数:easyxf, easyfont, add_palette_colour)
        :return:
        '''
        pass

3、创建一个不带样式的基础Excel表

import xlwt
# 实例化一个工作簿对象
workbook = xlwt.Workbook(encoding = 'utf-8')

# 获取工作表对象Worksheet
worksheet = workbook.add_sheet('work_sheet')

# 向工作表中添加数据(参数对应 行, 列, 值)
for i in range(3):
    for j in range(3):
        worksheet.write(i,j, label = 'test_' + str(j),)

# 保存数据到硬盘
workbook.save(r'i:\Excel_test.xls')

最终我们会看到如下图所示:

python xlwt模块的使用解析

二、xlwt高级应用

Font:用于设置字体,字体大小,字体颜色,是否加粗,斜体,字体带下划线,删除线等。

Alignment:用于设置字体水平和垂直对齐、文本换行、缩进、方向/旋转、文本方向等。

Border:表格边框设置。

Background:单元格背景颜色。

1、字体类Font简介

class Font(object):

    def __init__(self):
        # twip = 1/20 of a point = 1/1440 of a inch
        # usually resolution == 96 pixels per 1 inch
        # (rarely 120 pixels per 1 inch or another one)

        self.height = 0x00C8 # 200: this is font with height 10 points 字体高度
        self.italic = False      # 斜体
        self.struck_out = False  # 删除线
        self.outline = False     # 字体轮廓(没发现有什么变化)
        self.shadow = False      # 字体阴影
        self.colour_index = 0x7FFF  # 这个字体颜色貌似有限制,没太搞懂,范围是0x00到0x35之间有颜色,超过这个范围都是黑色,最大不能超过0xFFFF否则会报错。
        self.bold = False  # 粗体
        self._weight = 0x0190 # 0x02BC gives bold font  # 字体宽度
        self.escapement = self.ESCAPEMENT_NONE  #字体在单元格中位置,0x00正常,0x01字体上标,0x02字体下标。
        self.underline = self.UNDERLINE_NONE  # 默认字体不带下划线,0x01单下划线,0x02和0x01差不多,0x21双下划线,0x02和0x21差不多
        self.family = self.FAMILY_NONE        # 不清楚做什么的,默认没有,0x01罗马家族,0x02瑞士家族,0x03现代家族,0x04脚本家族,0x05描述家族
        self.charset = self.CHARSET_SYS_DEFAULT  # 字符集,字符集选项
                                CHARSET_ANSI_LATIN          = 0x00
                                CHARSET_SYS_DEFAULT         = 0x01
                                CHARSET_SYMBOL              = 0x02
                                CHARSET_APPLE_ROMAN         = 0x4D
                                CHARSET_ANSI_JAP_SHIFT_JIS  = 0x80
                                CHARSET_ANSI_KOR_HANGUL     = 0x81
                                CHARSET_ANSI_KOR_JOHAB      = 0x82
                                CHARSET_ANSI_CHINESE_GBK    = 0x86
                                CHARSET_ANSI_CHINESE_BIG5   = 0x88
                                CHARSET_ANSI_GREEK          = 0xA1
                                CHARSET_ANSI_TURKISH        = 0xA2
                                CHARSET_ANSI_VIETNAMESE     = 0xA3
                                CHARSET_ANSI_HEBREW         = 0xB1
                                CHARSET_ANSI_ARABIC         = 0xB2
                                CHARSET_ANSI_BALTIC         = 0xBA
                                CHARSET_ANSI_CYRILLIC       = 0xCC
                                CHARSET_ANSI_THAI           = 0xDE
                                CHARSET_ANSI_LATIN_II       = 0xEE
                                CHARSET_OEM_LATIN_I         = 0xFF
        self.name = 'Arial'  # 字体

1.1创建一个改变默认字体样式的Excel

import xlwt
# 实例化一个工作簿对象
workbook = xlwt.Workbook(encoding = 'utf-8')

# 获取工作表对象Worksheet
worksheet = workbook.add_sheet('work_sheet')

# 实例化表格样式对象
xstyle = xlwt.XFStyle()

# 设置字体样式
xfont = xlwt.Font()
xfont.colour_index = 0x04  # 设置字体颜色
xfont.bold = True          # 字体加粗
xfont.height = 20 * 18     # 设置字体高度(20是基数不变,18是字号用于调整大小)
xfont.underline = 0x01     # 设置字体带下划线
xfont.name = '华文彩云'     # 设置字体

# 将字体对象赋值给样式对象
xstyle.font = xfont

for i in range(3):
    for j in range(3):
        # 向工作表中添加数据(参数对应 行, 列, 值,样式)
        worksheet.write(i,j, label = 'test_' + str(j),style=xstyle)

# 保存数据到硬盘
workbook.save(r'i:\2.xls')

如果一切顺利,打开2.xls会看到如下:

python xlwt模块的使用解析

2、 Alignment类简介

class Alignment(object):
    # 字体水平设置
    HORZ_GENERAL                = 0x00  # 正常显示
    HORZ_LEFT                   = 0x01  # 左对齐
    HORZ_CENTER                 = 0x02  # 居中
    HORZ_RIGHT                  = 0x03  # 右对齐
    HORZ_FILLED                 = 0x04  # 填充单元格
    HORZ_JUSTIFIED              = 0x05  # 显示在合理的位置
    HORZ_CENTER_ACROSS_SEL      = 0x06  # Centred across selection我觉得这个应该是显示在单元格的正当中,但测试发现和0x02效果一样只能是水平居中不能垂直居中
    HORZ_DISTRIBUTED            = 0x07  # Distributed汉字时字体是水平 平均分布在表格中,如果是英文字母则是水平居中显示。

    # 垂直设置
    VERT_TOP                    = 0x00  # 字体在单元格顶部
    VERT_CENTER                 = 0x01  # 字体垂直居中
    VERT_BOTTOM                 = 0x02  # 字体在单元格底部
    VERT_JUSTIFIED              = 0x03  # Justified (BIFF5-BIFF8X)在合理的位置显示
    VERT_DISTRIBUTED            = 0x04  # Distributed (BIFF8X)有垂直居中的效果,如果字体超过单元格范围会垂直分布显示

    # 字体方向(没用明白哈哈)
    DIRECTION_GENERAL           = 0x00  # BIFF8X  正常显示
    DIRECTION_LR                = 0x01
    DIRECTION_RL                = 0x02

    ORIENTATION_NOT_ROTATED     = 0x00
    ORIENTATION_STACKED         = 0x01
    ORIENTATION_90_CC           = 0x02
    ORIENTATION_90_CW           = 0x03

    ROTATION_0_ANGLE            = 0x00
    ROTATION_STACKED            = 0xFF  # 就这个是垂直显示

    WRAP_AT_RIGHT               = 0x01  # 自动换行
    NOT_WRAP_AT_RIGHT           = 0x00  # 默认不自动换行

    SHRINK_TO_FIT               = 0x01  # 将字体缩小到适合单元格大小
    NOT_SHRINK_TO_FIT           = 0x00  # 默认正常显示

    def __init__(self):
        self.horz = self.HORZ_GENERAL   # 水平设置,默认是正常显示
        self.vert = self.VERT_BOTTOM    # 垂直设置,默认字体在单元格底部
        self.dire = self.DIRECTION_GENERAL
        self.orie = self.ORIENTATION_NOT_ROTATED
        self.rota = self.ROTATION_0_ANGLE   
        self.wrap = self.NOT_WRAP_AT_RIGHT  # 如果数据超过单元格显示范围是否自动换行显示,默认不换行
        self.shri = self.NOT_SHRINK_TO_FIT  # 如果数据超过单元格范围会自动缩小字体来适应当前单元格的显示范围,默认不缩小字体。
        self.inde = 0
        self.merg = 0

2.1下面是一个小示例:

import xlwt
# 实例化一个工作簿对象
workbook = xlwt.Workbook(encoding = 'utf-8')

# 获取工作表对象Worksheet
worksheet = workbook.add_sheet('work_sheet')
# 实例化表格样式对象
xstyle = xlwt.XFStyle()

# 设置字体样式
xfont = xlwt.Font()
xfont.colour_index = 0x04  # 设置字体颜色
xfont.bold = True          # 字体加粗
xfont.height = 20 * 18     # 设置字体高度(20是基数不变,18是字号用于调整大小)
xfont.name = '宋体'         # 设置字体
 # 设置字体在单元格中的位置
xalig = xlwt.Alignment()
xalig.horz = 0x02   # 字体水平居中
xalig.vert = 0x01   # 字体水平居中

# 将字体对象赋值给样式对象
xstyle.font = xfont
xstyle.alignment = xalig
for i in range(3):
    for j in range(3):
        # 向工作表中添加数据(参数对应 行, 列, 值,样式)
        worksheet.write(i,j, label = 'test_'+str(j),style=xstyle)

# 保存数据到硬盘
workbook.save(r'i:\2.xls')

如果一切顺利你会看到如下所示:

python xlwt模块的使用解析

3、Border类简介

class Borders(object):
    NO_LINE = 0x00   # 无边框
    THIN    = 0x01   # 细边框
    MEDIUM  = 0x02   # 中号细边框
    DASHED  = 0x03   # 虚线边框
    DOTTED  = 0x04   # 点划线和虚线差不多
    THICK   = 0x05   # 粗边框
    DOUBLE  = 0x06   # 加粗边框
    HAIR    = 0x07   # 和虚线差不多
    #The following for BIFF8
    MEDIUM_DASHED               = 0x08   # 中号虚线
    THIN_DASH_DOTTED            = 0x09   # 细虚线
    MEDIUM_DASH_DOTTED          = 0x0A   # 中号带点的虚线
    THIN_DASH_DOT_DOTTED        = 0x0B   # 点划线
    MEDIUM_DASH_DOT_DOTTED      = 0x0C   # 中号点划线
    SLANTED_MEDIUM_DASH_DOTTED  = 0x0D   # 斜线虚线点组成的

    NEED_DIAG1      = 0x01
    NEED_DIAG2      = 0x01
    NO_NEED_DIAG1   = 0x00
    NO_NEED_DIAG2   = 0x00

    def __init__(self):
        # 设置边框
        self.left   = self.NO_LINE
        self.right  = self.NO_LINE
        self.top    = self.NO_LINE
        self.bottom = self.NO_LINE
        self.diag   = self.NO_LINE   # 不知道干嘛用的

        # 设置边框颜色
        self.left_colour   = 0x40
        self.right_colour  = 0x40
        self.top_colour    = 0x40
        self.bottom_colour = 0x40
        self.diag_colour   = 0x40

        # 不知道干嘛用的
        self.need_diag1 = self.NO_NEED_DIAG1
        self.need_diag2 = self.NO_NEED_DIAG2

3.1下面是带边框的小示例

import xlwt
# 实例化一个工作簿对象
workbook = xlwt.Workbook(encoding = 'utf-8')

# 获取工作表对象Worksheet
worksheet = workbook.add_sheet('work_sheet')
# 实例化表格样式对象
xstyle = xlwt.XFStyle()

# 设置字体样式
xfont = xlwt.Font()
xfont.colour_index = 0x04  # 设置字体颜色
xfont.bold = True          # 字体加粗
xfont.height = 20 * 18     # 设置字体高度(20是基数不变,18是字号用于调整大小)
xfont.name = '宋体'        # 设置字体
 # 设置字体在单元格中的位置
xalig = xlwt.Alignment()
xalig.horz = 0x02   # 字体水平居中
xalig.vert = 0x01   # 字体水平居中

# 设置边框
xborder = xlwt.Borders()
# 边框是斜,点虚线
xborder.left = 0x0d
xborder.top = 0x0d
xborder.right = 0x0d
xborder.bottom = 0x0d
# 边框颜色
xborder.bottom_colour = 0x35
xborder.top_colour = 0x8
xborder.left_colour = 0x012
xborder.right_colour = 0x4

# 设置样式
xstyle.font = xfont
xstyle.alignment = xalig
xstyle.borders = xborder
for i in range(3):
    for j in range(3):
        # 向工作表中添加数据(参数对应 行, 列, 值,样式)
        worksheet.write(i,j, label = 'test_'+str(j),style=xstyle)

# 保存数据到硬盘
workbook.save(r'i:\2.xls')

最终你会看到如下所示:

python xlwt模块的使用解析

4、背景类Background简介

class Pattern(object):
    # patterns 0x00 - 0x12
    NO_PATTERN      = 0x00
    SOLID_PATTERN   = 0x01

    def __init__(self):
        self.pattern = self.NO_PATTERN   # 是否设置背景,必须允许设置背景,pattern_fore_colour和pattern_back_colour才会生效
        self.pattern_fore_colour = 0x40  # 前景色不会影响单元格的边框
        self.pattern_back_colour = 0x41  # 后景会影响单元格的边框

4.1下面进行小示例:

import xlwt
# 实例化一个工作簿对象
workbook = xlwt.Workbook(encoding = 'utf-8')

# 获取工作表对象Worksheet
worksheet = workbook.add_sheet('work_sheet')
# 实例化表格样式对象
xstyle = xlwt.XFStyle()

# 设置字体样式
xfont = xlwt.Font()
xfont.colour_index = 0x04  # 设置字体颜色
xfont.bold = True          # 字体加粗
xfont.height = 20 * 18     # 设置字体高度(20是基数不变,18是字号用于调整大小)
xfont.name = '宋体'        # 设置字体
 # 设置字体在单元格中的位置
xalig = xlwt.Alignment()
xalig.horz = 0x02   # 字体水平居中
xalig.vert = 0x01   # 字体水平居中

# 设置边框
xborder = xlwt.Borders()
# 边框是斜,点虚线
xborder.left = 0x0d
xborder.top = 0x0d
xborder.right = 0x0d
xborder.bottom = 0x0d
# 边框颜色
xborder.bottom_colour = 0x35
xborder.top_colour = 0x8
xborder.left_colour = 0x012
xborder.right_colour = 0x4
# 设置单元格背景
xpattern = xlwt.Pattern()
xpattern.pattern = 0x01
xpattern.pattern_fore_colour = 0x05
# 设置样式
xstyle.font = xfont
xstyle.alignment = xalig
xstyle.borders = xborder
xstyle.pattern = xpattern
for i in range(3):
    for j in range(3):
        # 向工作表中添加数据(参数对应 行, 列, 值,样式)
        worksheet.write(i,j, label = 'test_'+str(j),style=xstyle)

# 保存数据到硬盘
workbook.save(r'i:\2.xls')

最终你会看到如下图所示:

python xlwt模块的使用解析

上述只是简单的介绍了xlwt最基础的方法,还有许多方法功能没有被列举出来,这里就不一一列举了。有兴趣的小伙伴可以自己看源码来实现自己想要的功能。

三、一些常用的方法简介

1、设置单元格行高,列宽。

目前没有找到好的办法,只能逐行逐列的设置。代码如下:

import xlwt
# 实例化一个工作簿对象
workbook = xlwt.Workbook(encoding = 'utf-8')

# 获取工作表对象Worksheet
worksheet = workbook.add_sheet('work_sheet')
# 实例化表格样式对象
xstyle = xlwt.XFStyle()

# 设置字体样式
xfont = xlwt.Font()
xfont.colour_index = 0x04  # 设置字体颜色
xfont.bold = True          # 字体加粗
xfont.height = 20 * 18     # 设置字体高度(20是基数不变,18是字号用于调整大小)
xfont.name = '宋体'        # 设置字体
 # 设置字体在单元格中的位置
xalig = xlwt.Alignment()
xalig.horz = 0x02   # 字体水平居中
xalig.vert = 0x01   # 字体水平居中

# 设置边框
xborder = xlwt.Borders()
# 边框是斜,点虚线
xborder.left = 0x0d
xborder.top = 0x0d
xborder.right = 0x0d
xborder.bottom = 0x0d
# 边框颜色
xborder.bottom_colour = 0x35
xborder.top_colour = 0x8
xborder.left_colour = 0x012
xborder.right_colour = 0x4
# 设置单元格背景
xpattern = xlwt.Pattern()
xpattern.pattern = 0x01
xpattern.pattern_fore_colour = 0x05

# 设置样式
xstyle.font = xfont
xstyle.alignment = xalig
xstyle.borders = xborder
xstyle.pattern = xpattern

for i in range(3):
    # 设置行高
    worksheet.row(i).height_mismatch = True
    worksheet.row(i).height = 20 * 30  # 20是基数*30是行的高度
    for j in range(3):
        # 向工作表中添加数据(参数对应 行, 列, 值,样式)
        data = 'test_'+str(j)
        worksheet.col(j).width = 256 * len(data) * 2  # 设置列宽,计算列宽度:256是单元格基数*用数据长度*2最终的结果单元格的宽度和数据正好填满。
        worksheet.write(i,j, label = data,style=xstyle)

# 保存数据到硬盘
workbook.save(r'i:\2.xls')

最终会看到如下效果

python xlwt模块的使用解析

2、在单元格中显示日期,代码如下:

import xlwt
import datetime
# 实例化一个工作簿对象
workbook = xlwt.Workbook(encoding = 'utf-8')

# 获取工作表对象Worksheet
worksheet = workbook.add_sheet('work_sheet')
# 实例化表格样式对象
xstyle = xlwt.XFStyle()

# 设置字体样式
xfont = xlwt.Font()
xfont.colour_index = 0x04  # 设置字体颜色
xfont.bold = True          # 字体加粗
xfont.height = 20 * 18     # 设置字体高度(20是基数不变,18是字号用于调整大小)
xfont.name = '宋体'        # 设置字体
 # 设置字体在单元格中的位置
xalig = xlwt.Alignment()
xalig.horz = 0x02   # 字体水平居中
xalig.vert = 0x01   # 字体水平居中

# 设置边框
xborder = xlwt.Borders()
# 边框是斜,点虚线
xborder.left = 0x0d
xborder.top = 0x0d
xborder.right = 0x0d
xborder.bottom = 0x0d
# 边框颜色
xborder.bottom_colour = 0x35
xborder.top_colour = 0x8
xborder.left_colour = 0x012
xborder.right_colour = 0x4
# 设置单元格背景
xpattern = xlwt.Pattern()
xpattern.pattern = 0x01
xpattern.pattern_fore_colour = 0x05

# 设置样式
xstyle.font = xfont
xstyle.alignment = xalig
xstyle.borders = xborder
xstyle.pattern = xpattern
xstyle.num_format_str = 'M/D/YY'  # 日期显示格式,还有很多其它数据类型的选项,请参考下文。

for i in range(3):
    # 设置行高
    worksheet.row(i).height_mismatch = True
    worksheet.row(i).height = 20 * 30  # 20是基数*30是行的高度
    for j in range(3):
        # 向工作表中添加数据(参数对应 行, 列, 值,样式)
        data = datetime.datetime.now()   # 获取当前日期
        worksheet.col(j).width = 256 * len(data.strftime('%Y-%m-%d')) * 2  # 计算列宽度:256是单元格基数*用数据长度*2最终的结果单元格的宽度和数据正好填满。
        worksheet.write(i,j, label = data,style=xstyle)

# 保存数据到硬盘
workbook.save(r'i:\2.xls')

如果一切顺利效果如下:

python xlwt模块的使用解析

对于财务或者其他日期时间,小数,科学计数等显示格式,参考如下选项:

_std_num_fmt_list = [
            'general',     # 默认是此选项,常规显示。
            '0',
            '0.00',
            '#,##0',
            '#,##0.00',
            '"$"#,##0_);("$"#,##0)',
            '"$"#,##0_);[Red]("$"#,##0)',
            '"$"#,##0.00_);("$"#,##0.00)',
            '"$"#,##0.00_);[Red]("$"#,##0.00)',
            '0%',
            '0.00%',
            '0.00E+00',
            '# ?/?',
            '# ??/??',
            'M/D/YY',      # 这是我们刚刚用的
            'D-MMM-YY',
            'D-MMM',
            'MMM-YY',
            'h:mm AM/PM',
            'h:mm:ss AM/PM',
            'h:mm',
            'h:mm:ss',
            'M/D/YY h:mm',
            '_(#,##0_);(#,##0)',
            '_(#,##0_);[Red](#,##0)',
            '_(#,##0.00_);(#,##0.00)',
            '_(#,##0.00_);[Red](#,##0.00)',
            '_("$"* #,##0_);_("$"* (#,##0);_("$"* "-"_);_(@_)',
            '_(* #,##0_);_(* (#,##0);_(* "-"_);_(@_)',
            '_("$"* #,##0.00_);_("$"* (#,##0.00);_("$"* "-"??_);_(@_)',
            '_(* #,##0.00_);_(* (#,##0.00);_(* "-"??_);_(@_)',
            'mm:ss',
            '[h]:mm:ss',
            'mm:ss.0',
            '##0.0E+0',
            '@'
    ]
xstyle.num_format_str = 'M/D/YY'  # 我们只需将这个字符串替换上面我们需要的即可。

3、在Excel表格中插入公式,代码如下:

import xlwt
# 实例化一个工作簿对象
workbook = xlwt.Workbook(encoding = 'utf-8')

# 获取工作表对象Worksheet
worksheet = workbook.add_sheet('work_sheet')
# 实例化表格样式对象
xstyle = xlwt.XFStyle()

# 设置字体样式
xfont = xlwt.Font()
xfont.colour_index = 0x04  # 设置字体颜色
xfont.bold = True          # 字体加粗
xfont.height = 20 * 18     # 设置字体高度(20是基数不变,18是字号用于调整大小)
xfont.name = '宋体'        # 设置字体
 # 设置字体在单元格中的位置
xalig = xlwt.Alignment()
xalig.horz = 0x02   # 字体水平居中
xalig.vert = 0x01   # 字体水平居中

# 设置边框
xborder = xlwt.Borders()
# 边框是斜,点虚线
xborder.left = 0x0d
xborder.top = 0x0d
xborder.right = 0x0d
xborder.bottom = 0x0d
# 边框颜色
xborder.bottom_colour = 0x35
xborder.top_colour = 0x8
xborder.left_colour = 0x012
xborder.right_colour = 0x4
# 设置单元格背景
xpattern = xlwt.Pattern()
xpattern.pattern = 0x01
xpattern.pattern_fore_colour = 0x05

# 设置样式
xstyle.font = xfont
xstyle.alignment = xalig
xstyle.borders = xborder
xstyle.pattern = xpattern


for i in range(3):
    # 设置行高
    worksheet.row(i).height_mismatch = True
    worksheet.row(i).height = 20 * 30  # 20是基数*30是行的高度
    for j in range(3):
        # 向工作表中添加数据(参数对应 行, 列, 值,样式)
        worksheet.write(i,j, label = int(j)+1,style=xstyle)
# 设置行高
worksheet.row(3).height_mismatch = True
worksheet.row(3).height = 20 * 30  # 20是基数*30是行的高度
worksheet.write(3,0, label = xlwt.Formula('SUM(A1:A3)'),style=xstyle)  # 求和函数
worksheet.write(3,1, label = xlwt.Formula('B1*B2*B3'),style=xstyle)    # 求乘积
worksheet.write(3,2, label = xlwt.Formula('AVERAGE(C1:C3)'),style=xstyle)  # 求平均数

# 保存数据到硬盘
workbook.save(r'i:\2.xls')

最终我们会看到如下效果:

python xlwt模块的使用解析

4、在表格中插入超链接,代码如下:

import xlwt
# 实例化一个工作簿对象
workbook = xlwt.Workbook(encoding = 'utf-8')

# 获取工作表对象Worksheet
worksheet = workbook.add_sheet('work_sheet')
# 实例化表格样式对象
xstyle = xlwt.XFStyle()

# 设置字体样式
xfont = xlwt.Font()
xfont.colour_index = 0x04  # 设置字体颜色
xfont.bold = True          # 字体加粗
xfont.height = 20 * 18     # 设置字体高度(20是基数不变,18是字号用于调整大小)
xfont.name = '宋体'        # 设置字体
 # 设置字体在单元格中的位置
xalig = xlwt.Alignment()
xalig.horz = 0x02   # 字体水平居中
xalig.vert = 0x01   # 字体水平居中

# 设置边框
xborder = xlwt.Borders()
# 边框是斜,点虚线
xborder.left = 0x0d
xborder.top = 0x0d
xborder.right = 0x0d
xborder.bottom = 0x0d
# 边框颜色
xborder.bottom_colour = 0x35
xborder.top_colour = 0x8
xborder.left_colour = 0x012
xborder.right_colour = 0x4
# 设置单元格背景
xpattern = xlwt.Pattern()
xpattern.pattern = 0x01
xpattern.pattern_fore_colour = 0x05

# 设置样式
xstyle.font = xfont
xstyle.alignment = xalig
xstyle.borders = xborder
xstyle.pattern = xpattern

# 设置行高
worksheet.row(0).height_mismatch = True
worksheet.row(0).height = 20 * 30  # 20是基数*30是行的高度
a_data = 'HYPERLINK("http://www.baidu.com";"baidu")'   # 要插入的网址,'baidu'是在Excel中显示的值。
worksheet.col(0).width = 256 * len(a_data) * 2 # 设置单元格宽度
worksheet.write(0,0, label = xlwt.Formula(a_data),style=xstyle)  # 插入超链接

# 保存数据到硬盘
workbook.save(r'i:\2.xls')

如果一切顺利你会看到如下:

python xlwt模块的使用解析

5、关于颜色映射表如下:

_colour_map_text = """\
aqua 0x31
black 0x08
blue 0x0C
blue_gray 0x36
bright_green 0x0B
brown 0x3C
coral 0x1D
cyan_ega 0x0F
dark_blue 0x12
dark_blue_ega 0x12
dark_green 0x3A
dark_green_ega 0x11
dark_purple 0x1C
dark_red 0x10
dark_red_ega 0x10
dark_teal 0x38
dark_yellow 0x13
gold 0x33
gray_ega 0x17
gray25 0x16
gray40 0x37
gray50 0x17
gray80 0x3F
green 0x11
ice_blue 0x1F
indigo 0x3E
ivory 0x1A
lavender 0x2E
light_blue 0x30
light_green 0x2A
light_orange 0x34
light_turquoise 0x29
light_yellow 0x2B
lime 0x32
magenta_ega 0x0E
ocean_blue 0x1E
olive_ega 0x13
olive_green 0x3B
orange 0x35
pale_blue 0x2C
periwinkle 0x18
pink 0x0E
plum 0x3D
purple_ega 0x14
red 0x0A
rose 0x2D
sea_green 0x39
silver_ega 0x16
sky_blue 0x28
tan 0x2F
teal 0x15
teal_ega 0x15
turquoise 0x0F
violet 0x14
white 0x09
yellow 0x0D"""

好啦!!!就先简单写到这里吧。以后发现什么好玩的功能,在继续补充。

以上就是python xlwt模块的使用解析的详细内容,更多关于python xlwt模块的使用的资料请关注三水点靠木其它相关文章!

Python 相关文章推荐
Python Web服务器Tornado使用小结
May 06 Python
python中zip和unzip数据的方法
May 27 Python
Python内置的HTTP协议服务器SimpleHTTPServer使用指南
Mar 30 Python
Python中join函数简单代码示例
Jan 09 Python
Python 实现一行输入多个值的方法
Apr 21 Python
对Python实现简单的API接口实例讲解
Dec 10 Python
Python之循环结构
Jan 15 Python
python实现移位加密和解密
Mar 22 Python
Python数据类型之List列表实例详解
May 08 Python
python 的topk算法实例
Apr 02 Python
Python如何重新加载模块
Jul 29 Python
利用Python优雅的登录校园网
Oct 21 Python
python 爬取豆瓣网页的示例
简述python四种分词工具,盘点哪个更好用?
Apr 13 #Python
python自动化调用百度api解决验证码
利用Python网络爬虫爬取各大音乐评论的代码
用Python制作灯光秀短视频的思路详解
python实现socket简单通信的示例代码
使用Selenium实现微博爬虫(预登录、展开全文、翻页)
You might like
PHP文件上传原理简单分析
2011/05/29 PHP
163的邮件用phpmailer发送(实例详解)
2013/06/24 PHP
php中文验证码实现方法
2015/06/18 PHP
使用php从身份证号中获取一系列线索(星座、生肖、生日等)
2016/05/11 PHP
PHP获取input输入框中的值去数据库比较显示出来
2016/11/16 PHP
php使用变量动态创建类的对象用法示例
2017/02/06 PHP
Phpstorm+Xdebug断点调试PHP的方法
2018/05/14 PHP
php中对象引用和复制实例分析
2019/08/14 PHP
sina的lightbox效果。
2007/01/09 Javascript
js输出列表实现代码
2010/09/12 Javascript
Javascript的&&和||的另类用法
2014/07/23 Javascript
JS操作COOKIE实现备忘记录的方法
2016/04/01 Javascript
ionic中列表项增加和删除的实现方法
2017/01/22 Javascript
微信小程序实现留言板(Storage)
2018/11/02 Javascript
关于vue-cli 3配置打包优化要点(推荐)
2019/04/22 Javascript
vue使用echarts实现水平柱形图实例
2020/09/09 Javascript
NodeJS和浏览器中this关键字的不同之处
2021/03/03 NodeJs
[02:54]DOTA2英雄基础教程 撼地者
2014/01/14 DOTA
[01:26]神话结束了,却也刚刚开始——DOTA2新英雄玛尔斯驾临战场
2019/03/10 DOTA
使用PyCharm配合部署Python的Django框架的配置纪实
2015/11/19 Python
常见python正则用法的简单实例
2016/06/21 Python
详解Python 2.6 升级至 Python 2.7 的实践心得
2017/04/27 Python
浅谈python中copy和deepcopy中的区别
2017/10/23 Python
Python pymongo模块用法示例
2018/03/31 Python
python处理两种分隔符的数据集方法
2018/12/12 Python
Python小进度条显示代码
2019/03/05 Python
解决Keras 自定义层时遇到版本的问题
2020/06/16 Python
使用Tensorflow-GPU禁用GPU设置(CPU与GPU速度对比)
2020/06/30 Python
美国一家专业的太阳镜网上零售商:Solstice太阳镜
2016/07/25 全球购物
简述使用ftp进行文件传输时的两种登录方式?它们的区别是什么?常用的ftp文件传输命令是什么?
2016/11/20 面试题
Servlet的实例是在生命周期什么时候创建的?配置servlet最重要的是什么?
2012/05/30 面试题
道路交通安全实施方案
2014/03/12 职场文书
高考标语大全
2014/06/05 职场文书
高一作文之乐趣
2019/11/21 职场文书
Python Django 后台管理之后台模型属性详解
2021/04/25 Python
分布式锁为什么要选择Zookeeper而不是Redis?看完这篇你就明白了
2021/05/21 Redis