python使用pandas实现数据分割实例代码

作者:llwang_10 时间:2021-07-02 11:09:19 

本文研究的主要是Python编程通过pandas将数据分割成时间跨度相等的数据块的相关内容,具体如下。

先上数据,有如下dataframe格式的数据,列名分别为date、ip,我需要统计每5s内出现的ip,以及这些ip出现的频数。


ip   date
0 127.0.0.21 15/Jul/2017:18:22:16
1 127.0.0.13 15/Jul/2017:18:22:16
2 127.0.0.11 15/Jul/2017:18:22:17
3 127.0.0.11 15/Jul/2017:18:22:20
4 127.0.0.21 15/Jul/2017:18:22:21
5 127.0.0.13 15/Jul/2017:18:22:22
6 127.0.0.14 15/Jul/2017:18:26:36
7 127.0.0.16 15/Jul/2017:18:32:15
8 127.0.0.11 15/Jul/2017:18:36:03

在网上找了很久但是没看到python的相关答案,但在stackoverflow找到了R语言的解法,有兴趣可以看看。

受它的启发,我用不太优雅的方式实现了我的需求,有更好解决方法的请不吝赐教:

step1: 将数据中日期格式变为标准格式


#date_ip为我的dataframe数据
date_ip['date'] = pd.to_datetime(date_ip['date'], format='%d/%b/%Y:%H:%M:%S')

step2: 将数据的开始时间、结束时间,按5s分割(由于时间段可能不是恰好是5s的倍数,为避免最后一个时间丢失,因此在最后加上5s)


frequency = 5
time_range = pd.date_range(date_ip['date'][0],
   date_ip['date'][date_ip.shape[0]-1]
   +frequency*Second(), freq='%sS'%frequency)

step3: 将date变为索引


date_ip = date_ip.set_index('date')

step4: 对每个时间段内的数据进行频数计算(由于通过标签切片时会包含头、尾数据,为避免重复计算,因此在尾部减1s)


for i in xrange(0,len(time_range)-1):
print get_frequency(date_ip.loc[time_range[i]:time_range[i+1]-1*Second()])

完整的代码


import pandas as pd
from pandas.tseries.offsets import Second
def get_frequency(date_ip):
ip_frequency = {}
for i in xrange(0,date_ip.shape[0]):
ip_frequency[date_ip['ip'][i]] = ip_frequency.get(date_ip['ip'][i], 0) + 1
return ip_frequency,date_ip.shape[0]

if __name__ == '__main__':
date_ip['date'] = pd.to_datetime(date_ip['date'], format='%d/%b/%Y:%H:%M:%S')

frequency = 5
time_range = pd.date_range(date_ip['date'][0], date_ip['date'][date_ip.shape[0]-1]
   +frequency*Second(), freq='%sS'%frequency)
date_ip = date_ip.set_index('date')
for i in xrange(0, len(time_range) - 1):
print get_frequency(date_ip.loc[time_range[i]:time_range[i + 1]-1*Second()])

文章开头数据运行结果:


({'127.0.0.21' : 1, '127.0.0.13' : 1, '127.0.0.11' : 2}, 4)
({'127.0.0.21': 1, '127.0.0.13': 1}, 2)
({'127.0.0.14': 1}, 1)
({'127.0.0.16': 1}, 1)
({'127.0.0.11': 1}, 1)

总结

来源:http://blog.csdn.net/llwang_10/article/details/78590333

标签:python,pandas,数据
0
投稿

猜你喜欢

  • python两个_多个字典合并相加的实例代码

    2023-05-05 07:50:33
  • Go语言流程控制之goto语句与无限循环

    2023-08-31 06:43:00
  • sqlserver 触发器教程

    2024-01-15 08:38:17
  • 关于windows下Tensorflow和pytorch安装教程

    2023-06-09 07:35:54
  • 树莓派4B安装Tensorflow的方法步骤

    2023-09-05 17:28:06
  • Python实现RLE格式与PNG格式互转

    2021-07-11 18:23:19
  • MySQL中Like概念及用法讲解

    2024-01-21 01:12:07
  • 简单谈谈python中的语句和语法

    2023-03-03 12:03:13
  • MySQL中二进制与重做日志文件的基本概念学习教程

    2024-01-19 07:59:19
  • Python插入Elasticsearch操作方法解析

    2021-08-30 01:47:09
  • python模拟表单提交登录图书馆

    2021-11-06 19:20:42
  • 在Python程序中进行文件读取和写入操作的教程

    2023-05-22 10:31:56
  • Python基于分水岭算法解决走迷宫游戏示例

    2021-08-04 17:41:37
  • 详解python中的数据类型和控制流

    2022-08-11 14:32:50
  • MySQL性能优化

    2024-01-18 11:14:00
  • python实现抽奖小程序

    2022-06-10 14:14:29
  • python中强制关闭线程与协程与进程方法

    2023-05-11 10:24:48
  • 利用python实现汉字转拼音的2种方法

    2023-12-08 09:58:50
  • Go语言开发中redis的使用详解

    2024-02-14 12:58:27
  • Python爬虫获取整个站点中的所有外部链接代码示例

    2021-03-01 09:52:39
  • asp之家 网络编程 m.aspxhome.com