0


python数据分析基础006 -利用pandas带你玩转excel表格(上篇)

文章要点

🐚作者简介:苏凉(专注于网络爬虫,数据分析)
🐳博客主页:苏凉.py的博客
👑名言警句:海阔凭鱼跃,天高任鸟飞。
📰要是觉得博主文章写的不错的话,还望大家三连支持一下呀!!!
👉关注✨点赞👍收藏📂

在这里插入图片描述

🍺前言

在上篇文章中我们学习了一些pandas的基本使用,在数据分析中我们可以利用pandas对excel表格进行操作,包括对excel的创建,修改和读取等等。接下来我们一起来学习如何利用pandas对excel表格操作吧!!
往期回顾:

1.python数据分析基础001 -matplotlib的基础绘图
2.python数据分析基础002 -使用matplotlib绘图(散点图,条形图,直方图)
3.python数据分析基础003 -numpy的使用(详解)
4.python数据分析基础004 -numpy读取数据以及切片,索引的使用
5.python数据分析基础005 -pandas详解_pandas入门这一篇就足够了

🍁(一)创建文件

平时我们创建excel文件时,通常是在文件夹内右击新建excel表格,在pandas中只需一行代码即可!!
注:excel表格的文件格式为.xlsx

运行时报错:No module named ‘openpyxl’
这是我们在使用openpyxl包时没有安装该模块!因此我们需要在控制台输入指令:

pip install openpyxl

此时问题就解决啦!!

import pandas as pd

df = pd.DataFrame()
df.to_excel('D:/Temp01/test.xlsx')print('创建成功!!')

结果:
在这里插入图片描述

🍒1.在创建的表格内插入数据

只需将我们定义的数据传入Dataframe内即可:

import pandas as pd

numb_list ={'ID':[1,2,3,4],'name':['苏凉','jake','佚名','Tom'],'age':[22,18,25,16],'QQ_num':[787991021,2544722208,12545654,58456]}
df = pd.DataFrame(numb_list)
df.to_excel('D:/Temp01/test.xlsx')print('创建成功!!')

运行结果:
在这里插入图片描述

🍒2.修改索引

利用set_index设置索引

df = df.set_index('ID')

结果:
在这里插入图片描述

🍁(二)读取文件

🍒1.导入excel表格

people = pd.read_excel('./People.xlsx')#导入excel表格

🍒2.查看表格形状

print(people.shape)#查看有多少行多少列

🍒3.查看列名

x = people.columns
for i in x:print(i)

结果:

在这里插入图片描述

✨3.1 当第一行为空或有其他数据

在这里插入图片描述
在这里插入图片描述

遇到上述两种情况在读取列名时,pandas默认第一行为列名,当第一行为空时则需要设置header=某行

import pandas as pd

people = pd.read_excel('./People.xlsx',header =1)print(people.columns)

✨3.2 自定义列名

当打开的文件没有列名时,我们需要设置列名。
在这里插入图片描述

import pandas as pd

people = pd.read_excel('./People.xlsx',header=None)# 自定义列名
people.columns=['ID','Type','Title','FirstName','MiddleName','LastName']
people.set_index('ID',inplace=True)print(people.columns)# 保存
people.to_excel('./test.xlsx')print('save success')

结果:
在这里插入图片描述

✨3.3 指定索引

在上面我们创建了一个test文件。当我们再次打开时,pandas会给我们重新创建一个索引,如下图:
在这里插入图片描述
这时我们需要指定索引

import pandas as pd

people = pd.read_excel('./test.xlsx',index_col="ID")
people.to_excel('./test1.xlsx')print('save success')

结果:
在这里插入图片描述

🍒4.用Series创建行,列,单元格

import pandas as pd

d1 = pd.Series([10,20,30],index=[1,2,3],name='a')
d2 = pd.Series([40,50,60],index=[1,2,3],name='b')
d3 = pd.Series([100,200,300],index=[2,3,4],name='c')

df = pd.DataFrame({d1.name:d1,d2.name:d2,d3.name:d3})
df2 = pd.DataFrame([d1,d2,d3])print(df)print('*'*100)print(df2)

结果:
在这里插入图片描述

从上述结果可以看出通过Series创建的值传到Dataframe时需要用字典的形式,否则索引会自动转换为列。

🍒5.利用pandas实现excel自动填充

✨5.1 填充普通序列

实例:填充ID,InStore,Date
在这里插入图片描述

import pandas as pd

books = pd.read_excel('./Books.xlsx',skiprows=3,usecols='C:F',dtype={'ID':str})
df = pd.DataFrame(books)for i in books.index:# 对id自动填充
    books['ID'].at[i]= i+1# 对Instore自动填充
    books['InStore'].at[i]='no'if i%2==0else'yes'print(books)

结果:
在这里插入图片描述

✨5.2 填充日期序列

填充日期序列时,我们需要事先从datetime中导入date,timedelda模块

from datetime import date,timedelta

设置初始日期

 start_time = date(2019,1,25)

🎐5.2.1 填充日

books['Date'].at[i]= start_time + timedelta(days=i)

结果:
在这里插入图片描述
注:timedelda最多只能加到日期,无法加年以及月!!

🎐5.2.2 填充年

 books['Date'].at[i]= date(start_time.year+i,start_time.month,start_time.day)

结果:
在这里插入图片描述

🎐5.2.3 填充月(难点!!!)

在填充月份时我们需要注意月份最高为12月,若>12月则从1月开始

定义月份的时间函数:

# d -日期 ,md—月的该变量defadd_month(d,md):# 得到含有多少年
    yd = md//12# 获取月份
    m = d.month +md%12#     判断是否满足条件if m !=12:
        yd += m//12
        m = m%12return date(d.year +yd ,m ,d.day)

下面自动填充月份时调用函数:

    books['Date'].at[i]= add_month(start_time ,i)

结果:
在这里插入图片描述

✨5.3 源码及保存

import pandas as pd
from datetime import date,timedelta

# d -日期 ,md—月的该变量defadd_month(d,md):# 得到含有多少年
    yd = md//12# 获取月份
    m = d.month +md%12#     判断是否满足条件if m !=12:
        yd += m//12
        m = m%12return date(d.year +yd ,m ,d.day)

books = pd.read_excel('./Books.xlsx',skiprows=3,usecols='C:F',dtype={'ID':str})
df = pd.DataFrame(books)
start_time = date(2019,1,25)for i in books.index:# 对id自动填充
    books['ID'].at[i]= i+1# 对Instore自动填充
    books['InStore'].at[i]='no'if i%2==0else'yes'# 对日自动填充# books['Date'].at[i] = start_time#     对年自动填充
    books['Date'].at[i]= date(start_time.year+i,start_time.month,start_time.day)#       对月份自动填充
    books['Date'].at[i]= add_month(start_time ,i)

books.set_index('ID',inplace=True)
books.to_excel('./book1.xlsx')print('save success')

结果:
在这里插入图片描述

🍻结语

今天的学习到这里就结束啦,下期内容要点:
1.函数填充
2.排序
3.数据筛选
4.数据可视化
关注我,咱们下期再见!!

在这里插入图片描述


本文转载自: https://blog.csdn.net/weixin_46277553/article/details/123988736
版权归原作者 苏凉.py 所有, 如有侵权,请联系我们删除。

“python数据分析基础006 -利用pandas带你玩转excel表格(上篇)”的评论:

还没有评论