五分钟学会四种宽数据转长数据方法——Excel、Mysql、R、python

本文主要是介绍五分钟学会四种宽数据转长数据方法——Excel、Mysql、R、python,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在学Mysql中的时候,想必大家都曾遇到如下的题:将表1转为表2,
表1

CompanyNameSale2013Sale2014Sale2015Sale2016
Apple苹果5000505050505050
Google谷歌3500380038003800
Facebook脸书2300290029002900

表2

CompanyNameYearSales
Apple苹果Sale20135000
Google谷歌Sale20133500
Facebook脸书Sale20132300
Apple苹果Sale20145050
Google谷歌Sale20143800
Facebook脸书Sale20142900
Apple苹果Sale20155050
Google谷歌Sale20153800
Facebook脸书Sale20152900
Apple苹果Sale20165050
Google谷歌Sale20153800
Facebook脸书Sale20162900

这实际上就是宽表转长表。今天,分享一下分别在MySQL、excel、R、python中实现宽表转长表的方法。

目录

        • 一、Mysql
        • 二、Excel
        • 三、R
        • 四、python

一、Mysql

实现的关键字:union all

#准备数据
create table items(Company varchar(10),Name varchar(10),Sale2013 int,Sale2014 int,Sale2015 int, Sale2016 int);insert into items values("Apple","苹果",5000,5050,5050,5050),("Google","谷歌",3500,3800,3800,3800),("Facebook","脸书",2300,2900,2900,2900);
select Company,Name,
'Sale2013' as 'Year',`Sale2013` as 'Sales' from items union all
select Company,Name,
'Sale2014' as 'Year',`Sale2014` as 'Sales' from items union all
select Company,Name,
'Sale2015' as 'Year',`Sale2015` as 'Sales' from items union all
select Company,Name,
'Sale2016' as 'Year',`Sale2016` as 'Sales' from items;

在这里插入图片描述

二、Excel

实现关键词:PowerQuery逆透视

(1)数据——从表格——表包含标题
在这里插入图片描述
(2)选中Company,Name列——转换——逆透视其他列
在这里插入图片描述
(3)修改列名——关闭并上载至

在这里插入图片描述

三、R

实现关键词:gather

#准备数据
df=data.frame(Company=c("Apple","Google","Facebook"),Name=c("苹果","谷歌","脸书"),Sale2013=c(5000,3500,2300),Sale2014=c(5050,3800,2900),Sale2015=c(5050,3800,2900),Sale2016=c(5050,3800,2900))
library(tidyr)
gather(df,key="Year",value="Sales",Sale2013:Sale2016)

key:转换后新的列名
value:转换后值的新列名
Sale2013:Sale2016 : 需要转列的字段

在这里插入图片描述

四、python

实现关键词:set_index+stack+reset_indexmelt(有点类似R中的gather)

方法一:set_index+stack+reset_index

stack可以将行索引转为列索引,但Company、Name这列是没有变化的,所以需要先将其设置为索引,具体实现方法如下:

import pandas as pd
import os
os.chdir('C:/Users/dell/Desktop')
data=pd.read_excel('data.xlsx',encoding='utf-8')
df=data.set_index(['Company','Name']).stack().reset_index()
df.columns=['Company','Name','Year','Sales']

在这里插入图片描述

方法二:melt

data.melt(id_vars=['Company','Name'],var_name='Year',value_name='Sales')

在这里插入图片描述
id_vars:保持不变的列索引
var_name:行索引转列索引后新的列名 (类似R中的KEY)
value_name:value_name:新索引对应的值的列名 (类似R中的VALUE)

这篇关于五分钟学会四种宽数据转长数据方法——Excel、Mysql、R、python的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/456270

相关文章

Python中你不知道的gzip高级用法分享

《Python中你不知道的gzip高级用法分享》在当今大数据时代,数据存储和传输成本已成为每个开发者必须考虑的问题,Python内置的gzip模块提供了一种简单高效的解决方案,下面小编就来和大家详细讲... 目录前言:为什么数据压缩如此重要1. gzip 模块基础介绍2. 基本压缩与解压缩操作2.1 压缩文

MySQL 删除数据详解(最新整理)

《MySQL删除数据详解(最新整理)》:本文主要介绍MySQL删除数据的相关知识,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、前言二、mysql 中的三种删除方式1.DELETE语句✅ 基本语法: 示例:2.TRUNCATE语句✅ 基本语

golang中reflect包的常用方法

《golang中reflect包的常用方法》Go反射reflect包提供类型和值方法,用于获取类型信息、访问字段、调用方法等,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值... 目录reflect包方法总结类型 (Type) 方法值 (Value) 方法reflect包方法总结

Python设置Cookie永不超时的详细指南

《Python设置Cookie永不超时的详细指南》Cookie是一种存储在用户浏览器中的小型数据片段,用于记录用户的登录状态、偏好设置等信息,下面小编就来和大家详细讲讲Python如何设置Cookie... 目录一、Cookie的作用与重要性二、Cookie过期的原因三、实现Cookie永不超时的方法(一)

MySQL中查找重复值的实现

《MySQL中查找重复值的实现》查找重复值是一项常见需求,比如在数据清理、数据分析、数据质量检查等场景下,我们常常需要找出表中某列或多列的重复值,具有一定的参考价值,感兴趣的可以了解一下... 目录技术背景实现步骤方法一:使用GROUP BY和HAVING子句方法二:仅返回重复值方法三:返回完整记录方法四:

Python内置函数之classmethod函数使用详解

《Python内置函数之classmethod函数使用详解》:本文主要介绍Python内置函数之classmethod函数使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录1. 类方法定义与基本语法2. 类方法 vs 实例方法 vs 静态方法3. 核心特性与用法(1编程客

从入门到精通MySQL联合查询

《从入门到精通MySQL联合查询》:本文主要介绍从入门到精通MySQL联合查询,本文通过实例代码给大家介绍的非常详细,需要的朋友可以参考下... 目录摘要1. 多表联合查询时mysql内部原理2. 内连接3. 外连接4. 自连接5. 子查询6. 合并查询7. 插入查询结果摘要前面我们学习了数据库设计时要满

C# 比较两个list 之间元素差异的常用方法

《C#比较两个list之间元素差异的常用方法》:本文主要介绍C#比较两个list之间元素差异,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. 使用Except方法2. 使用Except的逆操作3. 使用LINQ的Join,GroupJoin

Python函数作用域示例详解

《Python函数作用域示例详解》本文介绍了Python中的LEGB作用域规则,详细解析了变量查找的四个层级,通过具体代码示例,展示了各层级的变量访问规则和特性,对python函数作用域相关知识感兴趣... 目录一、LEGB 规则二、作用域实例2.1 局部作用域(Local)2.2 闭包作用域(Enclos

Python实现对阿里云OSS对象存储的操作详解

《Python实现对阿里云OSS对象存储的操作详解》这篇文章主要为大家详细介绍了Python实现对阿里云OSS对象存储的操作相关知识,包括连接,上传,下载,列举等功能,感兴趣的小伙伴可以了解下... 目录一、直接使用代码二、详细使用1. 环境准备2. 初始化配置3. bucket配置创建4. 文件上传到os