数据集笔记:Telecom Shanghai Dataset

0 数据地址

📱Telecom Shanghai Dataset (kaggle.com)

1 数据描述

  • 该数据集由上海电信提供,包含超过720万条记录,记录了9481部手机通过3233个基站访问互联网的情况,时间跨度为六个月。
  • 例如,下图显示了基站的分布情况。每个节点代表中国上海的一个基站。
  • 这个数据集可以帮助研究人员评估他们在移动边缘计算主题上的解决方案,如边缘服务器部署、服务迁移、服务推荐等。

2 数据介绍

  • 电信数据集展示了6个参数,例如月份、数据、开始时间、结束时间、基站位置、手机ID。
  • 通过数据集可以找到用户的轨迹。

每15天一个表

3 python读取+可视化

3.1 读取数据

python 复制代码
import pandas as pd

data=pd.read_excel('Downloads/Telecom Shanghai Dataset/data_10.110.15.xlsx',names=['Data','start time','end time','cell station lon','cell station lat','user id'])

3.2 剔除经纬度为NaN的record

python 复制代码
data1=data.dropna()
data1

3.3 选择某一天的数据

python 复制代码
import datetime
data2=data1[(data1['start time']>=datetime.datetime(2014,10,15)) & (data1['start time']<datetime.datetime(2014,10,16))]
data2

3.4 根据user id和时间排序

python 复制代码
data2=data2.sort_values(by=['user id','start time'])
data2

3.5 停留的记录只保留第一条

3.5.1 首先确定哪些时刻在移动

记录当前位置和前一时刻的位置

python 复制代码
data2['location']=data2['cell station lon'].astype(str)+'_'+data2['cell station lat'].astype(str)
data2
python 复制代码
data2['prev_location']=data2['location'].shift(1)
data2
python 复制代码
data2['location_changed']=(data2['location']!=data2['prev_location'])
data2

3.5.2 保留当前时刻在移动的记录

python 复制代码
data3=data2[data2['location_changed']==True]
data3
python 复制代码
data3=data3[[ 'start time', 'end time', 'cell station lon',
       'cell station lat', 'user id']]
data3

3.6 保留轨迹长度大于10的轨迹

计算每一个用户id出现的次数

python 复制代码
iid=data3.groupby('user id').size().reset_index(name='count')
iid
python 复制代码
iid['count'].describe()
'''
count    2956.000000
mean        4.675237
std         4.769128
min         1.000000
25%         2.000000
50%         3.000000
75%         6.000000
max        69.000000
Name: count, dtype: float64
'''
python 复制代码
iid=iid[iid['count']>10]
iid
python 复制代码
data4=data3[data3['user id'].isin(iid['user id'])]
data4

3.7 绘制一条轨迹(使用folium)

python 复制代码
import numpy as np
tmp=data4[data4['user id']=='00a05a4f2b937fd38888c03213c4deb2'].reset_index()
tra_lst=[]
for j in range(tmp.shape[0]):
        tra_lst.append([tmp.at[j,'cell station lon'],tmp.at[j,'cell station lat']])
tra_lst=np.array(tra_lst)
m=folium.Map(location=tra_lst.mean(axis=0),zoom_start=13)
for i in tra_lst:
    folium.Marker(location=i).add_to(m)
folium.PolyLine(locations=tra_lst).add_to(m)
    
m
相关推荐
Vince丶2 小时前
“伪”局域网
笔记
johnny2333 小时前
编辑器和笔记软件汇总(三):NotebookLM、note-gen、MiaoYan、LetsMarkdown、DocFlow
笔记
虫洞没有虫3 小时前
Go语言学习笔记(一)
笔记·go·区块链
小马爱打代码3 小时前
RabbitMQ:系统学习笔记
笔记·学习·rabbitmq
YJlio3 小时前
进程和诊断工具速查手册(8.13):VMMap / DebugView / LiveKd / Handle / ListDLLs 一页式现场排障清单
数据库·笔记·学习
alwaysuzybaiyy5 小时前
物联网控制|计算机控制-刘川来胡乃平版|第4章:过程通道与人机接口-4.4Human-Machine Interface|课堂笔记|
笔记·物联网·powerpoint
弘毅 失败的 mian5 小时前
C++、Java 还是测试开发?
java·c++·经验分享·笔记·测试开发·技术方向·就业
AA陈超6 小时前
ASC学习笔记0019:返回给定游戏属性的当前值,如果未找到该属性则返回零。
c++·笔记·学习·游戏·ue5·虚幻引擎
星星202510 小时前
VSCode插件精选:4款高效UML绘图工具
笔记
lkbhua莱克瓦2415 小时前
Java基础——方法
java·开发语言·笔记·github·学习方法