数据分析(pandas)---09.案例

import pandas as pd
import numpy as np

order = pd.read_table('meal_order_info.csv',
                    sep=',',encoding='gbk')
print('原始数据:\n',order.shape)

# 由于表中的日期数据为字符串类型,
# 所以在进行日期操作之前,
# 需要将它们转成TimeStape

order['use_start_time'] = pd.to_datetime(order['use_start_time'])
order['lock_time'] = pd.to_datetime(order['lock_time'])

# 时间差
order['time'] = order['lock_time']-order['use_start_time']
print(order['time'].head())
# 异常值的处理
# 1.判断这一列是否有空值,如果有删除该行数据
index_null = order.index[order['time'].isnull()]

# 删除 inplace是否作用在原始数据表
order.drop(labels=index_null,axis=0,inplace=True)
print('剔除空值后表的数据:\n',order.shape)

# 2.关于负值的清洗,lock_time<start_time

mask = order['lock_time']<order['use_start_time']
index_positive = order.index[mask]
order.drop(labels=index_positive,axis=0,inplace=True)
print('剔除time为负值后的数据:\n',order.shape)

print(order['time'].head())
# 点餐时间大于1天为异常数据
# print(order['time'].tail(50))
# fp = pd.ExcelWriter('清洗数据.xlsx')
order.to_excel('清洗数据.xlsx','Sheet1')
# fp.save()

# str
# 序列.str:表示将序列中的元素(按行),以字符串的形式来展示

# 生成过滤序列[False,True.........]把True过滤掉
mask = order['time'].astype('str').str.split().str[0].astype('int')>0#字符串中第一位的值
# print(order['time'].astype('str').str.split().str[0])
index_exception = order.index[mask]
order.drop(labels=index_exception,axis=0,inplace=True)

print('异常值清洗后的标的数据为:',order.shape)

print(order['time'].min())
print(order['time'].max())
print(order['time'].mean())

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值