返回顶部
首页 > 资讯 > 精选 >Pandas怎么封装Excel工具类
  • 545
分享到

Pandas怎么封装Excel工具类

2023-07-06 04:07:50 545人浏览 泡泡鱼
摘要

这篇文章主要介绍了pandas怎么封装excel工具类的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Pandas怎么封装Excel工具类文章都会有所收获,下面我们一起来看看吧。引言Excel是一种广泛使用的电子

这篇文章主要介绍了pandas怎么封装excel工具类的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Pandas怎么封装Excel工具类文章都会有所收获,下面我们一起来看看吧。

引言

Excel是一种广泛使用的电子表格软件,它提供了大量的数据处理和计算功能,被广泛应用于数据分析和报告中。在python中,我们可以使用pandas库来读写和处理Excel文件。但是,为了更方便和快速地操作Excel文件,我们可以封装一个Excel工具类,提供常用的读写操作方法,以提高开发效率。

1、列表转Excel文件

这个方法可以将数据集列表转换为Excel文件。该方法使用pd.ExcelWriter()创建Excel文件写入器,然后使用pd.DataFrame()创建一个数据帧对象,再将其写入Excel文件中。

#!/usr/bin/python3# -*- coding: utf-8 -*-# @Author: Hui# @Desc: { Excel文件操作工具模块 }# @Date: 2022/04/03 19:34import pandas as pdfrom typing import List, UNIOn, Dict, ioclass ExcelUtils(object):    """ Excel文件操作工具类 """    @claSSMethod    def list_to_excel(            cls,            path_or_buffer: Union[str, IO],            data_list: list,            col_mapping: dict = None,            sheet_name: str = 'Sheet1',            **kwargs    ):        """        列表转 excel文件        Args:            path_or_buffer: 文件路径或者缓冲流            data_list: 数据集 List[dict]            col_mapping: 表头列字段映射            sheet_name: sheet名称        Returns:        """        with pd.ExcelWriter(path_or_buffer) as writer:            _col_mapping = list(col_mapping) if col_mapping else None            df = pd.DataFrame(data=data_list, columns=_col_mapping)            if col_mapping:                df.rename(columns=col_mapping, inplace=True)            df.to_excel(writer, sheet_name=sheet_name, index=False, **kwargs)

这里path_or_buffer可以是一个文件路径或者一个缓冲流对象,data_list是一个列表,包含需要写入Excel的数据。col_mapping是一个字典,用于将表头列字段映射到数据集的字段名。

# 示例user_list = [    dict(id=1, name='hui', age=20),    dict(id=2, name='wang', age=22),    dict(id=3, name='zack', age=25),]user_col_mapping = {    'id': '用户id',    'name': '用户名',    'age': '年龄',}ExcelUtils.list_to_excel('user.xlsx', user_list, col_mapping=user_col_mapping)# 导出为excel文件字节流处理 excel_bio = BytesIO()ExcelUtils.list_to_excel(    excel_bio,    data_list=user_list,    col_mapping=user_col_mapping,    sheet_name='demo') excel_bytes = excel_bio.getvalue()print("excel_bytes type => ", type(excel_bytes))>>>outexcel_bytes type =>  <class 'bytes'>

Pandas怎么封装Excel工具类

这个例子将一个用户数据集写入一个Excel文件中,并将列名映射为中文,也可以将excel保存在缓存流中(字节数据),在一些WEB场景中可以更方便的将缓冲流响应给前端、或者上传到一些OSS中,这样就不用创建临时文件、读取、上传。

2、多个列表转Excel文件

如果有多个数据集需要写入到同一个Excel文件中,可以使用该方法。它与前面的方法类似,但接受一个列表,列表中包含多个数据集及其对应的表头列字段映射和sheet名称。

将多个数据列表写入到一个Excel文件中。

@classmethoddef multi_list_to_excel(        cls,        path_or_buffer: Union[str, IO],        data_collects: List[tuple],        **kwargs):    """    多列表转带不同 sheet的excel文件    Args:        path_or_buffer: 文件路径或者缓冲流        data_collects: 大数据集 list[(data_collect, col_mapping, sheet_name)]            data_collect: 数据集,            col_mapping: 列字段映射,            sheet_name: excel表sheet名称    Returns:    """    with pd.ExcelWriter(path_or_buffer) as writer:        for data_collect, col_mapping, sheet_name in data_collects:            df = pd.DataFrame(data=data_collect, columns=list(col_mapping))            df.rename(columns=col_mapping, inplace=True)            df.to_excel(writer, sheet_name=sheet_name, index=False, **kwargs)

参数说明:

  • path_or_buffer: 文件路径或者缓冲流;

  • data_collects: 多个数据列表的元组集合,每个元组包含三个元素:需要写入到Excel文件中的数据列表,列名与字典key的映射,Excel文件的sheet名称。

示例:

user_list = [    {'id': 1, 'name': 'hui', 'age': 18},    {'id': 2, 'name': 'wang', 'age': 19},    {'id': 3, 'name': 'zack', 'age': 20}]book_list = [    {'id': 1, 'name': 'Python基础教程', 'author': 'hui', 'price': 30},    {'id': 2, 'name': 'Java高级编程', 'author': 'wang', 'price': 50},    {'id': 3, 'name': '机器学习实战', 'author': 'zack', 'price': 70},]user_col_mapping = {'id': '编号', 'name': '姓名', 'age': '年龄'}book_col_mapping = {'id': '编号', 'name': '书名', 'author': '作者', 'price': '价格'}data_collects = [    (user_list, user_col_mapping, '用户信息'),    (book_list, book_col_mapping, '图书信息')]ExcelUtils.multi_list_to_excel('multi_sheet_data.xlsx', data_collects)

Pandas怎么封装Excel工具类

感觉这方法参数太多,不太容易知道如何入参,后续可以用dataclass抽出结构来入参这样更好理解点。

3、读取Excel表格数据

@classmethoddef read_excel(        cls,        path_or_buffer: Union[str, IO],        sheet_name: str = "Sheet1",        col_mapping: dict = None,        all_col: bool = True,        header: int = 0,        **kwargs) -> List[dict]:    """    读取excel表格数据,根据col_mapping替换列名    Args:        path_or_buffer: 文件路径或者缓冲流        sheet_name: 读书excel表的sheet名称        col_mapping: 列字段映射        all_col: True返回所有列信息,False则返回col_mapping对应的字段信息        header: 默认0从第一行开启读取,用于指定从第几行开始读取    Returns:    """    use_cols = None    if not all_col:        # 获取excel表指定列数据        use_cols = list(col_mapping) if col_mapping else None    df = pd.read_excel(path_or_buffer, sheet_name=sheet_name, usecols=use_cols, header=header, **kwargs)    if col_mapping:        df.rename(columns=col_mapping, inplace=True)    return df.to_dict("records")

示例代码:

data = [    {"id": 1, "name": "hui", "age": 30},    {"id": 2, "name": "zack", "age": 25},    {"id": 3, "name": "wang", "age": 40},]# 将数据写入Excel文件ExcelUtils.list_to_excel("read_demo.xlsx", data, col_mapping={"id": "用户ID", "name": "姓名", "age": "年龄"})# 读取Excel文件result = ExcelUtils.read_excel("read_demo.xlsx", col_mapping={"用户ID": "id", "姓名": "name"})print(result)>>>out[{'id': 1, 'name': 'hui'}, {'id': 2, 'name': 'zack'}, {'id': 3, 'name': 'wang'}]

可以将字典列表数据根据列字段映射转换成中文表头的excel,读取excel时也可以将中文表头转成对应业务字段。

有些模板excel文件默认前几行是说明文字,因此可以指定header参数来跳过这些说明文字,这里只是把一些常用的参数封装了下,**kwargs 还是可以使用pandas的一些参数。

4、合并多个Excel文件到一个文件中(每个文件对应一个工作表)

@classmethoddef merge_excel_files(        cls,        input_files: List[str],        output_file: str,        sheet_name_mapping: Dict[str, str] = None,        **kwargs):    """    合并多个Excel文件到一个文件中(每个文件对应一个工作表)    如果Excel文件有多个作表,则默认取第一个工作表    Args:        input_files: 待合并的excel文件列表        output_file: 输出文件路径        sheet_name_mapping: 文件工作表映射,默认为文件名            {"文件名1": "sheet1", "文件名2": "sheet2"}    Returns:    """    sheet_name_mapping = sheet_name_mapping or {}    with pd.ExcelWriter(output_file, **kwargs) as writer:        for file in input_files:            df = pd.read_excel(file)            sheet_name = sheet_name_mapping.get(file, file)            df.to_excel(writer, sheet_name=sheet_name, index=False)

示例:

def merge_excel_files_demo():    # 合并多个Excel文件    ExcelUtils.merge_excel_files(        input_files=["user.xlsx", "multi_sheet_data.xlsx"],        output_file="merged_data.xlsx",        sheet_name_mapping={            "user.xlsx": "user",            "multi_sheet_data.xlsx": "multi_sheet_data"        }    )

Pandas怎么封装Excel工具类

关于“Pandas怎么封装Excel工具类”这篇文章的内容就介绍到这里,感谢各位的阅读!相信大家对“Pandas怎么封装Excel工具类”知识都有一定的了解,大家如果还想学习更多知识,欢迎关注编程网精选频道。

--结束END--

本文标题: Pandas怎么封装Excel工具类

本文链接: https://lsjlt.com/news/357822.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Pandas怎么封装Excel工具类
    这篇文章主要介绍了Pandas怎么封装Excel工具类的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Pandas怎么封装Excel工具类文章都会有所收获,下面我们一起来看看吧。引言Excel是一种广泛使用的电子...
    99+
    2023-07-06
  • Pandas封装Excel工具类的方法步骤
    目录引言1、列表转Excel文件2、多个列表转Excel文件3、读取Excel表格数据4、合并多个Excel文件到一个文件中(每个文件对应一个工作表)引言 Excel是一种广泛使用的...
    99+
    2023-05-16
    Pandas封装Excel Pandas Excel封装
  • 封装JDBC工具类
    封装JDBC工具类 在实际JDBC的使用中,存在着大量的重复代码:例如连接数据库、关闭数据库等这些操作! 我们需要把传统的JDBC代码进行重构,抽取出通用的JDBC工具类!以后连接的任何数据库、释放资源都可以使用这个工具类 重用性...
    99+
    2017-12-18
    封装JDBC工具类 数据库入门 数据库基础教程
  • Java利用Reflect实现封装Excel导出工具类
    目录定义ExcelExportEnum定义导出方法校验入参利用java反射获取Service中的所有method提取method中的入参对象,获取其Class传入参数,调用导出方法注...
    99+
    2022-11-13
    Java Reflect封装Excel导出工具类 Java Excel导出 Java Reflect
  • java封装Mongodb3.2.1工具类
           由于最近项目要使用mongodb来处理一些日志,提前学习了一下mongodb的一些基本用法,大概写了一些常用的。     ...
    99+
    2024-04-02
  • HttpClient 4.0封装工具类是怎样的
    这篇文章将为大家详细讲解有关HttpClient 4.0封装工具类是怎样的,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。以下为本人在实际开发过程中封装的HttpClient工具类,HttpC...
    99+
    2023-06-03
  • 怎么在java中封装一个JDBC工具类
    本篇文章给大家分享的是有关怎么在java中封装一个JDBC工具类,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。Java是什么Java是一门面向对象编程语言,可以编写桌面应用程序...
    99+
    2023-06-06
  • javascript常用工具类如何封装
    小编给大家分享一下javascript常用工具类如何封装,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!前言因为工作中经常用到这些...
    99+
    2024-04-02
  • 使用Java导入、导出excel详解(附有封装好的工具类)
    😜作           者:是江迪呀✒️本文关键词:Java、Excel、导出、工具类、后端☀️每日   一言:有些事情不是对的才去坚持,而是坚持了它才是对的! 前言 我们在日常开发中,一定遇到过要将数据导出为Exc...
    99+
    2023-08-18
    java excel 开发语言
  • C#串口通信工具类的封装
    本文实例为大家分享了C#串口通信工具类的封装代码,供大家参考,具体内容如下  1、SerialPortHelper串口工具类封装 using System; using S...
    99+
    2024-04-02
  • Java日期工具类的封装详解
    概述 在日常的开发中,我们难免会对日期格式化,对日期进行计算,对日期进行校验,为了避免重复写这些琐碎的逻辑,我这里封装了一个日期工具类,方便以后使用,直接复制代码到项目中即可使用。 ...
    99+
    2022-11-13
    Java日期工具类 Java日期类
  • 【JAVA高级】——吃透JDBC中的封装工具类、ORM和Date工具类
    ✅作者简介:热爱国学的Java后端开发者,修心和技术同步精进。 🍎个人主页:乐趣国学的博客 🍊个人信条:不迁怒,不贰过。小知识,大智慧。 💞当前专栏:JAVA开发者成长之路 ...
    99+
    2023-08-31
    数据库 java mysql
  • 基于fluttertoast怎么实现封装弹框提示工具类
    本文小编为大家详细介绍“基于fluttertoast怎么实现封装弹框提示工具类”,内容详细,步骤清晰,细节处理妥当,希望这篇“基于fluttertoast怎么实现封装弹框提示工具类”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来...
    99+
    2023-06-30
  • Android封装的http请求实用工具类
    代码如下:import java.io.BufferedReader;import java.io.InputStreamReader;import java.net.URL...
    99+
    2022-06-06
    工具类 HTTP 工具 http请求 Android
  • Redis工具类封装RedisUtils的使用示例
    此RedisUtil工具类的功能: 直接使用此RedisUtil工具类的所需条件: 项目基于SpringBoot。pom.xml中需要引入依赖spring-boot-starter...
    99+
    2024-04-02
  • 利用怎么对Java输出打印工具类进行封装
    这篇文章将为大家详细讲解有关利用怎么对Java输出打印工具类进行封装,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。在进行Java打印输出,进行查看字段值的时候,觉得每次写了System.ou...
    99+
    2023-05-31
    java ava
  • Redis缓存穿透/击穿工具类的封装
    目录1. 简单的步骤说明2. 逻辑缓存数据类型3. 缓冲工具类的封装3.1 CacheClient 类的类图结构3.2 CacheClient 类代码1. 简单的步骤说明 创建一个逻辑缓存数据类型 封装缓冲穿透和缓冲击穿...
    99+
    2022-07-27
    Redis缓存穿透 Redis缓存击穿 Redis缓存穿透缓存击穿
  • java8日期工具类封装的实战记录
    目录前言在Java 8中如何处理日期和时间再封装Java8新增的日期、时间包总结前言 java现在应该是更新到16了,想想我当年刚参加工作的时候。普遍还都是java7,那时候没有Sp...
    99+
    2024-04-02
  • 如何在java中封装一个JDBC工具类
    如何在java中封装一个JDBC工具类?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。Java是什么Java是一门面向对象编程语言,可以编写桌面应用程序、Web应用程序、分布...
    99+
    2023-06-14
  • C#串口通信工具类的封装方法
    本篇内容介绍了“C#串口通信工具类的封装方法”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! 1、SerialPortHelper串...
    99+
    2023-06-29
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作