数据导出excel的通用python代码

news/2024/7/21 3:46:37 标签: excel, python

excel_0">将数据导出excel的通用代码

在实际的项目开发中,一些重要数据需要保存到excel文件中,或者需要提供下载的功能,都会用到将数据导出excel的代码。

本文介绍了将数据导出excel的通用python代码,对创建excel文件、写数据等过程进行了封装,开箱即用,且可复用。

python">import string
import xlsxwriter
from faker import Faker


def export_to_excel(filename, col_items, datas):
    """将信息导出为excel文件

    Args:
        filename (str): 文件名
        col_items (list): 列名
        datas (list): 数据信息

    """

    # 生成.xlsx文件
    workbook = xlsxwriter.Workbook(f'{filename}.xlsx')

    # 设置sheet页签名称
    table = workbook.add_worksheet(filename)

    # 表头居中,背景灰色,字体颜色为白色
    header_format = workbook.add_format({'align': 'center', 
                                         'bg_color': 'gray',
                                         "color": "white", 
                                         "font": "宋体", 
                                         "bold": True, 
                                         "border": 1})

    # 数据样式:居中,带边框,字体
    data_format = workbook.add_format({'align': 'center', "border": 1})
    data_format.set_font("Calibri Light")  

    # 26个英文字母,大写
    chars = string.ascii_uppercase

    # 设置列名及宽度
    for idx, col in enumerate(col_items):
        # 列名,宽度
        col_name, col_width = col
        col_code = chars[idx]

        # 写入列名
        table.write(0, idx, col_name, header_format)
        table.set_column(f'{col_code}:{col_code}', col_width)

    # 列数
    col_num = len(col_items)
    # 循环写入数据
    for index, item in enumerate(datas):
        # 一行为一条数据
        row = index + 1
        for i in range(col_num):
            table.write(row, i, item[i], data_format)

    # 关闭
    workbook.close()


if __name__ == "__main__":

    # 构造数据
    faker_obj = Faker(locale='zh')

    # 文件名
    filename ='人员名单' 

    # 列名
    cols = [('序号', 10), ('姓名', 20)]

    # 构造数据
    datas= []
    for i in range(10):
        datas.append((i + 1, faker_obj.name()))

    # 将数据信息导出到excel文件中
    export_to_excel(filename, cols, datas)

测试上述代码,生成的excel文件如下图所示:
在这里插入图片描述


http://www.niftyadmin.cn/n/5312988.html

相关文章

低压 5V 全桥驱动芯片GC9114 ,适用于摄像机、消费类等产品上

GC9114 是一款低压 5V 全桥驱动芯片,为摄像机、消费类产品、玩具和其他低压或者电池供电的运动控制类应用提供了集成的电机驱动解决方案。 GC9114 能提供高达 1.3A 的持续输出电流。可以工作在 2~6V 的电源电压上。具有 PWM(IN/IN)输入接口,与…

探秘 JAVA 工厂模式:深度详解与实例分析

探秘 JAVA 工厂模式:深度详解与实例分析 前言: 欢迎阅读本篇博客,我们将深入研究 Java 中一种设计模式——工厂模式。工厂模式是一种创建型模式,它提供了创建对象的最佳方式之一,有助于将对象的创建与使用解耦。 1. 工厂模式简…

前端使用scale属性结合CSS动态样式实现动态的图片缩放效果

废话不多说&#xff0c;直接上代码&#xff1a; 示例一&#xff0c;使用css动态样式结合scale进行src图片的缩放。 //结构层&#xff0c;使用动态属性配合计算属性来实现动态样式<img :src"selectedItem.url" alt"" :style"elementStyle(item)&…

【Python学习】Python学习8-Number

目录 【Python学习】Python学习8-Number 前言在变量赋值时被创建Python支持四种不同的数据类型整型(Int)长整型(long integers&#xff09;浮点型(loating point real values)复数(complex numbers) Python Number 类型转换Python math 模块、cmath 模块Python数学函数Python随…

数据结构之AVL Tree

系列文章目录 数据结构之B树和B树 数据结构之Radix和Trie 数据结构可视化演示链接&#xff0c;也就是视频中的网址 文章目录 系列文章目录先上演示定义使用场景实时系统中的调度器&#xff1a;文件系统中的索引结构&#xff1a; 先上演示 AVL Tree 定义 最先发明的自平衡二叉…

ai 饭前茶点小说(2)

张俊伟是一个普通而害羞的大学生&#xff0c;他深深地爱上了同班的女孩莫清淋。莫清淋是一个温柔而优雅的女孩&#xff0c;她总是给人一种神秘而迷人的感觉。每当张俊伟看到她微笑的时候&#xff0c;心里都会不由自主地跳动起来。 张俊伟对莫清淋的感情愈发深沉&#xff0c;他每…

基于Github官方教程的快速入门学习

GitHub 是一个用于版本控制和协作的代码托管平台。 它允许您和其他人随时随地协同处理项目。 创建仓库 在任何页面的右上角&#xff0c;使用 下拉菜单选择“新建存储库”。 之后会进入创建仓库的界面&#xff0c;需要我们进行如下操作&#xff1a; 写仓库的名字写对于本仓库…

【MySQL】utft8mb4 字符集及其排序规则(字符集校验规则)

UTF-8 是 Unicode 的一种实现方式&#xff0c;它可以表示世界上绝大多数的字符&#xff0c;包括大部分的中文字符。MySQL 从 5.5.3 版本开始支持 UTF-8 字符集&#xff0c;其中包括 UTF-8MB4。UTF-8MB4 是 MySQL 支持的最大的字符集&#xff0c;它可以表示 4 字节的 Unicode 字…