当前位置: 首页 > news >正文

数据集笔记:分析OpenCellID 不同radio/ create_time update_time可视化

1 读取数据

(以新加坡的cellID为例)

import geopandas as gpd
import pandas as pdopencellid=pd.read_csv('OpenCellID_SG.csv',header=None,names=['radio','mcc','net','area','cell','unit','lon','lat','range','samples','changeable1','created1','updated','AveSignal'])
opencellid

2 不同radio的比例

radio_gather=opencellid.groupby('radio').size()
radio_gather
'''
radio
GSM     10875
LTE     59369
NR        372
UMTS    61726
Name: mcc, dtype: int64
'''
import matplotlib.pyplot as pltplt.pie(radio_gather,labels=radio_gather.index)

3 created1 & update 

3.1 unix时间戳 转 datetime

opencellid['created1']=pd.to_datetime(opencellid['created1'],unit='s')
opencellid['updated']=pd.to_datetime(opencellid['updated'],unit='s')
opencellid

3.2 datetime截断到年

opencellid['created_year'] = opencellid['created1'].dt.year
opencellid['updated_year'] = opencellid['updated'].dt.year
opencellid

3.3 根据年份和radio聚合

created_grouped = opencellid.groupby(['created_year', 'radio']).size().reset_index(name='count')
created_grouped

updated_grouped = opencellid.groupby(['updated_year', 'radio']).size().reset_index(name='count')
updated_grouped

 

3.4 创建数据透视表

pandas 笔记:pivot_table 数据透视表\pivot_UQI-LIUWJ的博客-CSDN博客

created_pivot=created_grouped.pivot(index='created_year',columns='radio',values='count')
created_pivot

created_pivot=created_pivot.fillna(0).reset_index()
created_pivot

updated_pivot=updated_grouped.pivot(index='updated_year',columns='radio',values='count')
updated_pivot=updated_pivot.fillna(0).reset_index()
updated_pivot

3.5 绘制柱状图

from pyecharts.charts import Bar, Grid
from pyecharts import options as optsbar_created = (Bar(init_opts=opts.InitOpts(width='2000px')).add_xaxis(created_pivot['created_year'].astype(str).tolist()).add_yaxis("GSM", created_pivot['GSM'].tolist()).add_yaxis("LTE", created_pivot['LTE'].tolist()).add_yaxis("NR", created_pivot['NR'].tolist()).add_yaxis("UMTS", created_pivot['UMTS'].tolist()).set_global_opts(title_opts=opts.TitleOpts(title="Count of Created Radio Types per Year"))
)
'''
init_opts=opts.InitOpts(width='2000px') 设置柱状图的宽度
'''bar_updated = (Bar(init_opts=opts.InitOpts(width='2000px'))  # Set chart width.add_xaxis(updated_pivot['updated_year'].astype(str).tolist()).add_yaxis("GSM", updated_pivot['GSM'].tolist()).add_yaxis("LTE", updated_pivot['LTE'].tolist()).add_yaxis("NR", updated_pivot['NR'].tolist()).add_yaxis("UMTS", updated_pivot['UMTS'].tolist()).set_global_opts(title_opts=opts.TitleOpts(title="Count of Updated Radio Types per Year", pos_top="50%"))
)
#pos_top="50%" 设置第二张图title的位置# Creating a Grid
grid = (Grid(init_opts=opts.InitOpts(width='2000px')).add(bar_created, grid_opts=opts.GridOpts(pos_bottom="60%")).add(bar_updated, grid_opts=opts.GridOpts(pos_top="60%"))
)
#两张图叠起来# Save the grid as a .html file
grid.render("combined_chart.html")

http://www.lryc.cn/news/190461.html

相关文章:

  • 【特纳斯电子】血氧饱和度监测仪设计-实物设计
  • 雪花算法生成ID传到前端之后精度丢失问题
  • Windows 10 - 适用于各种服务(Redis、MySQL)的文件迁移到其他目录后,导致的各种服务找不到的问题 - 注册服务 - 关闭服务 - 重启服务
  • Java 串行接口调用优化
  • 【Java 进阶篇】JavaScript `typeof` 操作符详解
  • electron之进程间通信
  • Linux网络编程:UDP协议和TCP协议
  • 【SCS-CN】SCS-CN模型中CN值的确定
  • 【C++】继承 ① ( 面向对象特点 | 类之间的关系 | 单继承与多继承 | 继承关系特性 )
  • 虹科方案 | 虹科ATTO加速虚拟存储管理
  • Docker项目部署lnmp+wordpress
  • leetcode 121. 买卖股票的最佳时机、122. 买卖股票的最佳时机 II
  • 系统架构设计:5 论软件的可靠性设计
  • 03 独立看门狗 hal库 stm32cubemx
  • 大数据学习(6)-hive底层原理Mapreduce
  • SQLite:TIMESTAMP类型使用
  • 迅镭激光GI系列高功率激光切割机成功中标覆铜板龙头企业HZ公司
  • 基于SSM的网络安全宣传网站设计与实现
  • k8s修改集群IP--重置集群
  • 记录:R语言生成热图(非相关性)
  • 第55篇-某did滑块流程分析-滑动验证码【2023-10-12】
  • 正点原子嵌入式linux驱动开发——Linux内核顶层Makefile详解
  • C++ 笔记索引
  • Android攻城狮学鸿蒙-配置
  • SpringBoot 接口 字节数组直接显示为图片
  • 黄金票据与白银票据
  • 发稿渠道和发布新闻的步骤和技巧,收藏!
  • 【Leetcode】204. 计数质数
  • LRU自定义最近最少使用-java实现
  • spring:详解spring boot