Python3,Pandas 5行代码实现对excel 读写操作

pandas 写入excel数据

在使用pandas之前,需要安装pandas模块,
老方法:

pip install pandas

安装完成后,就可以直接使用了,
上代码

# -*- coding:utf-8 -*-
"""
@ auth : carl_DJ
@ time : 2020-8-13
"""
import pandas as pd
import  os

#DataFrame 数据帧,相当于工作簿中的一个工作表
df = pd.DataFrame({
    'id':[1,2,3,4],
    'name':['张三','李四','王五','赵刘'],
    'arg': [10,20,30,40],
    'score':[99,88,77,66]
})
#自定义索引,否则pandas会使用默认索引,导致工作表也会存在这些索引
cf = df.set_index('id')
# print(cf)
#设置文件保存路径
data_path = "../py_class/data"
#没有,则创建
if  not os.path.exists(data_path):
    os.mkdir(data_path)
#设置文件名,以xlsx格式
data_name = os.path.join(data_path,'data.xlsx')
#把DataFrame的数据写入excel表
cf.to_excel(data_name)

print("done")

最后执行完成,
使用id做索引,结果长这样
在这里插入图片描述

使用pandas默认索引,结果是酱样子的:
在这里插入图片描述

所以,要使用pandas默认索引还是 自己创建索引,看各个的喜欢~~

pandas 读取excel数据

读取excel的数据,也很简单,
咱先把各种情况,列举一下,然后在读取数据

#设置文件名字,没用os.path方法,因为这不是重点
data_name= '../py_class/data/data.xlsx'

#header=2表示从第三行开始(默认0),跳过前两行,sheet_name表示工作表名称
pepl = pd.read_excel(data_name,header=2,sheet_name="Sheet1")
# pepl = pd.read_excel(data_name,sheet_name="Sheet1")
#打印列名
# print(pepl.columns)

#sort_values 进行排序,by 针对某一行,ascending= False 表示从大到小,inplace = True  直接编辑当前的文档
pepl.sort_values(by = "score", ascending= False, inplace=True)
print(pepl)

#如果读取的excel中无开头标题,可将header=None,手动进行设置
pepl = pd.read_excel(data_name,header=None)
#设置 4个字段,id,name,arg,score
pepl.columns = ['id','name','arg','score']
print(pepl.columns)

#指定id列为索引
pepl = pd.read_excel(data_name,index_col = 'id')
#输出,此时就不会产生索引
print(pepl.head())

#skiprows开头跳过几行,usecols使用哪些列中的数据,dtype设置某一列的类型
pepl = pd.read_excel(data_name,skiprows = 4,usecols = 'E:H',dtype={"id":str,"gender":str,"brithday":str})

下面 我们就是演示一下,看看我们上面写的数据,输入情况如何

# -*- coding:utf-8 -*-
"""
@ auth : carl_DJ
@ time : 2020-8-13
"""

import pandas as pd

#设置文件名字
data_name= '../py_class/data/data.xlsx'

#读取data_name文件,sheet页是sheet1
peple = pd.read_excel(data_name,sheet_name="Sheet1")
#print(peple.head())

#sort_values 进行排序,by 针对sorce,ascending= False 表示从大到小,inplace = True  就地编辑
peple.sort_values(by = "score", ascending= False, inplace=True)
#
print(peple)

输出的结果,就酱样:
在这里插入图片描述

  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Carl_奕然

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值