python对excel操作简书_利用Python处理Excel数据

读取数据

import pandas as pd

import numpy as np

from datetime import datetime

from pandas import Series, DataFrame

读取x.xlsx文件

df = pd.read_excel('E:/工作文件/周报/周数据/测试/0902-0908/an-商品汇总-uv.xls')

df = pd.read_excel(r'E:\工作文件\周报\周数据\测试\0902-0908\an-商品汇总-uv.xls')

读取文件夹

import os

file_list_june = os.listdir(r'C:\Users\省资源位数据\孔-数据源合并')

读取txt文件

df = pd.read_table(r'C:\Users\Administrator\Desktop\haha.txt')

with open(r'C:\Users\Administrator\Desktop\haha.txt', 'r') as f:

df = f.readlines()

df = np.loadtxt(r'C:\Users\Administrator\Desktop\haha.txt') # 将txt文件存为numpy数组

读取csv格式Excel表

df = pd.read_csv('E:/工作文件/周报/周数据/测试/0902-0908/an-商品汇总-uv.xls')

df = pd.read_csv(r'E:\工作文件\周报\周数据\测试\0902-0908\an-商品汇总-uv.xls')

写入excel

data.to_excel('C:/Users/Administrator/Desktop/'+'商品分类.xlsx')

data.to_excel(r'C:\Users\Administrator\Desktop\\'+'商品分类.xlsx')

data.to_excel(r'C:\Users\Administrator\Desktop/'+'商品分类.xlsx')

显示数据

显示数据的行与列数

df.shape

(24247, 17)

有24247行,17列数据

查看数据格式dtpyes

df.dtypes

显示列名

df.columns

列名

添加默认列名

如果数据没有标题行,可用pandas添加默认的列名

df = pd.read_excel('x.xlsx', header = None)

显示前数据前5行

df.head(5)

显示数据后5行

df.tail(5)

显示数据唯一值(unique函数)

df['经纪人级别'].unique()

经纪人级别

级别为0 是因为对数据缺失值进行了填充

对第几行数据不读取

不读取哪里数据,可用skiprows=[i],跳过文件的第i行不读取

# 没有读取第2行

df = pd.read_excel('x.xlsx',skiprows=[2] )

对缺失值进行识别

# 所有缺失值显示为True

# df.isnull()

pd.insull(df)

显示缺失值

数据清洗

处理空值

删除空值 (dropna函数)

df.dropna(how='any')

填充空值(fillna函数)

# 空值用0填充

df.fillna(value=0)

用均值对空值进行填充

# 利用经纪人响应时长的均值对缺失值进行填充

df['经纪人响应时长'].fillna(df['经纪人响应时长'].mean())

更改数据格式

通过dtypes函数显示大区的数据格式为int64,现在改成float格式

df['大区'].astype('float64')

float64

更改列名称

df.rename(columns={'IM渠道': '渠道'})

删除重复值 (drop_duplicates()函数)

第一次出现的保留,其余删除

#使用默认第一次出现的被保留,后面出现的被删除

df['门店'].drop_duplicates()

最后一次出现的保留,其余删除

df['门店'].drop_duplicates(keep = 'last')

对列表内的值进行替换(replace函数)

df['客户UCID'].replace('10531975', '110')

数据预处理

对数据进行排序

df.sort_values(by=['客户当天发送消息数'])

数据分组——excel中的数据透视表

** 对客户聊天记录进行分组 **

#如果price列的值>3000,group列显示high,否则显示low

df['group'] = np.where(df['客户当天发送消息数'] > 5,'high','low')

df

分组

** 对符合多个条件进行分组**

# 符合经纪人级别为A1且经纪人响应时长>24的在sign列显示为1

df.loc[(df['经纪人级别'] == 'A1') & (df['经纪人响应时长']>= 24.0), 'sign']=1

df

符合多个条件

数据分列

pd.DataFrame((x.split('网') for x in df['客户注册渠道']),

index=df.index,columns=['客户注册渠道','size'])

分列

数据提取

按标签提取

loc函数

df.loc[0:3]

提取0-3行的数据

按日期进行提取

# 重新设置索引

df.reset_index()

#设置日期为索引

df=df.set_index('日期')

#提取2016年11月2号的数据

df['2016-11-02' : '2016-11-02']

按位置进行提取(iloc函数)

按区域提取

df.iloc[:4, :5]

按位置提取

#[0, 2, 5] 代表指定的行,[ 4, 5 ] 代表指定的列

df.iloc[[0,2,5],[4,5]]

按标签和位置提取 ix

# 行按日期排列,列按位置设置

df.ix['2016-11-03':'2016-11-03',4:6]

标签和位置

按条件提取(loc与isin函数)

用isin函数进行判断

# 判断经纪人级别是否为A3

df['经纪人级别'].isin(['A3'])

判断

先判断结果,将结果为True的提取

#先判断经纪人级别列里是否包含A3和M4,然后将复合条件的数据提取出来。

df.loc[df['经纪人级别'].isin(['A3','M4'])]

提取

从合并的数据中提出指定的数值

# 提取链家网三个字

data = df['客户注册渠道']

pd.DataFrame(data.str[:3])

提取指定数值

数据筛选

按条件筛选

符合多个条件,并显示指定条件(与)

#级别为M4,发送消息数大于110

df.loc[(df['经纪人当天发送消息数'] > 110) & (df['经纪人级别'] == 'M4'),

['经纪人响应时长','是否5分钟内响应','经纪人系统号']]

级别为M4,发送消息大于110

符合多个条件中的一个

#发送消息数大于400或响应时长大于60000

df.loc[(df['经纪人当天发送消息数'] > 400) | (df['经纪人响应时长'] > 60000.0),

['经纪人响应时长','经纪人系统号']].sort(['经纪人响应时长'])

#筛选完可直接求和

df.loc[(df['经纪人当天发送消息数'] > 400) | (df['经纪人响应时长'] > 60000.0),

['经纪人响应时长','经纪人系统号']].sort(['经纪人响应时长']).经纪人响应时长.sum()

不等于

df.loc[(df['经纪人当天发送消息数']!= 200) & (df['经纪人级别'] == 'A4'),

['经纪人响应时长','经纪人系统号']].sort(['经纪人响应时长'])

# count() 算总数

df.loc[(df['经纪人当天发送消息数']!= 200) & (df['经纪人级别'] == 'A4'),

['经纪人响应时长','经纪人系统号']].sort(['经纪人响应时长']).经纪人系统号.count()

使用query函数

df.query('经纪人级别 == ["A4", "M4"]')

A4或M4

数据汇总

分类汇总groupby

对所有列进行分类汇总

df.groupby('经纪人级别').count()

经纪人级别

对特定列进行汇总

df.groupby('经纪人级别')['经纪人响应时长'].count()

对响应时长列进行汇总

增加分类条件

df.groupby(['经纪人级别','经纪人是否回复'])['经纪人响应时长'].count()

数据不准确,因为进行了筛选填充

进行分组并进行算数运算

# 对经纪人响应时长进行分类汇总,并计算均值

df.groupby('经纪人级别')['经纪人响应时长'].agg([ np.mean])

分类,均值

数据透视

pd.pivot_table(df,index=["经纪人当天发送消息数"],values=["经纪人响应时长"],

columns=["经纪人级别"],aggfunc[len,np.sum],fill_value=0,margins=True)

数据统计

数据采样

简单随机抽取sample

df.sample(n=3)

随机抽取3行

设置采样权重

需要对每一行进行权重设置,列表行数少可行,过多不可行

假设有4行数据,设置采样权重

weights = [0, 0, 0.5, 0.5]

df.sample(n=4, weights=weights)

确定采样后是否放回

# 采样后放回,True

df.sample(n=6, replace=True)

描述统计 describe函数

自动生成数据的数量,均值,标准差等数据

#round(2),显示小数点后面2位数,T转置

df.describe().round(2).T

描述统计

标准差std()

df['经纪人响应时长'].std()

协方差cov

#计算两个字段之间的协方差

df['经纪人当天发送消息数'].cov(df['客户当天发送消息数'])

相关性分析corr

相关系数在-1到1之间,接近1为正相关,接近-1为负相关,0为不相关

df['客户当天发送消息数'].corr(df['经纪人当天发送消息数'])

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值