python实现Excel多行多列的转换的示例

 更新时间:2023年03月13日 09:52:32   作者:GISer_小汪汪  
本文主要介绍了python实现Excel多行多列的转换的示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

前言

使用pandas对Excel的多行和多列进行转换

提示:以下是本篇文章正文内容,下面案例可供参考

一、使用需求

将上表中的多行多列数据转换成下表中的三列多行数据,需要做的就是将同一日期不同坐标的值汇总到一列数据。核心思想就是新建一列然后把原来的一行多列数据汇总成一列多行数据。不同日期的值汇总到一起,即完成多行多列的转换。

二、使用步骤

1.引入库

import pandas as pd

2.读入数据

df = pd.read_excel('源数据.xlsx')

3.将需要合并的列的列名先放在列表中

merge_list = list(df.loc[:, '75.951142 39.473421':].columns)#这里是坐标,是日期右边的列名,可以根据自己的表格改。

4.填充空值为0

df.loc[:, '75.951142 39.473421':] = df.loc[:, '75.951142 39.473421':].fillna(0)

5.添加新列,把待合并的所有列变成一个大字符串(传入函数处理)

# 定义函数来处理合并操作
def merge_values(s):
    # 每2列进行合并分隔符为|,2列与2列合并分割符为#,即 监测值和坐标
    result = []
    for idx in range(0, len(s.values), 2):  # len(s.values)即df.loc[:,'学科':]的每一行的长度 ,第三个字段2为步长2即2个合并
        result.append(f'{s[idx]}|{merge_list[idx]}')  # 生成一个列表,格式为数值和坐标,这里merge_list[idx]是后面添加的坐标列
    return '#'.join(result)  # 将列表用#号分割返回一个大字符串 格式为:检测值和坐标
# 添加新列,把待合并的所有列变成一个大字符串(传入函数处理)
df['merge'] = df.loc[:, '75.951142 39.473421':].apply(merge_values, axis=1)

6.删除合并之前的列,保存id,name,merge列

df.drop(merge_list,axis=1,inplace=True)

7. 使用explode来变成多列

df['75.951142 39.473421'] = df['merge'].str.split('|').str[0]df['坐标'] = df['merge'].str.split('|').str[1]#这里添加新的坐标列df.drop(['merge'],axis=1,inplace=True)df['75.951142 39.473421'] = df['merge'].str.split('|').str[0]
df['坐标'] = df['merge'].str.split('|').str[1]#这里添加新的坐标列
df.drop(['merge'],axis=1,inplace=True)

8.存储到本地生成新的csv文件

df.to_excel('转换后数据.xlsx', index=False)

总结

以上就是今天要讲的内容,本文仅仅简单介绍了多行多列数据之间的转换的一个小案例,主要是利用pandas来解决。

到此这篇关于python实现Excel多行多列的转换的示例的文章就介绍到这了,更多相关python Excel多行多列转换内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • python 计算数据偏差和峰度的方法

    python 计算数据偏差和峰度的方法

    今天小编就为大家分享一篇python 计算数据偏差和峰度的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-06-06
  • Python中的图形绘制简单动画实操

    Python中的图形绘制简单动画实操

    这篇文章主要介绍了Python中的图形绘制简单动画实操, Matplotlib 是一个非常广泛的库,它也支持图形动画,动画工具以 matplotlib.animation 基类为中心,它提供了一个框架,围绕该框架构建动画,下面来看看具体的实现过程吧,需要的小伙伴可以参考一下
    2022-02-02
  • python 将json数据提取转化为txt的方法

    python 将json数据提取转化为txt的方法

    今天小编就为大家分享一篇python 将json数据提取转化为txt的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-10-10
  • python 装饰器重要在哪

    python 装饰器重要在哪

    这篇文章主要介绍了python 装饰器重要在哪,帮助大家更好的理解和使用python,感兴趣的朋友可以了解下
    2021-02-02
  • Python实现读取json文件到excel表

    Python实现读取json文件到excel表

    这篇文章主要介绍了Python实现读取json文件到excel表,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-11-11
  • python之ImportError:模块引入异常问题

    python之ImportError:模块引入异常问题

    这篇文章主要介绍了python之ImportError:模块引入异常问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-06-06
  • Django ModelSerializer实现自定义验证的使用示例

    Django ModelSerializer实现自定义验证的使用示例

    本文主要介绍了Django ModelSerializer实现自定义验证的使用示例,多种字段验证器帮助开发者确保数据的完整性和准确性,具有一定的参考价值,感兴趣的可以了解一下
    2023-11-11
  • Python计算斗牛游戏概率算法实例分析

    Python计算斗牛游戏概率算法实例分析

    这篇文章主要介绍了Python计算斗牛游戏概率算法,简单介绍了斗牛游戏的原理并结合具体实例形式分析了相关的游戏概率算法,需要的朋友可以参考下
    2017-09-09
  • python 实现弹球游戏的示例代码

    python 实现弹球游戏的示例代码

    这篇文章主要介绍了python 实现弹球小游戏,帮助大家更好的理解和学习python,感兴趣的朋友可以了解下
    2020-11-11
  • Python进程池Pool应用实例分析

    Python进程池Pool应用实例分析

    这篇文章主要介绍了Python进程池Pool应用,结合实例形式分析了Python进程池Pool功能、使用方法及相关操作注意事项,需要的朋友可以参考下
    2019-11-11

最新评论