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

交通数据处理-计算途径某些路段的车辆数

根据车辆的运行轨迹,计算先经过某些路段,再经过某些路段的车辆数。

欢迎关注本人公众号--交通数据探索师

如下表,

其中:vehicle: 车辆编号;route: 车辆轨迹。

以第一行为例,车辆car1按顺序经过了路段123、路段456、路段789。

现统计先通过路段123再通过路段789的车辆数。

大家可以可以先思考一下怎么使用Python和SQL进行实现。

 

Python

实现思路:以car1的轨迹为例,现将route拆分成列表['123', '456', '789'],判断该列表中是否包含路段123和路段789,如果包含则再进一步判断路段123在列表中的位置是不是在路段789的前面,如果也是,则该车辆满足要求。​

import pandas as pd
import numpy as np data = pd.DataFrame({'vehicle': ['car1', 'car2', 'car3', 'car4', 'car5'],'route': ['123+456+789', '1123+789+357', '123+456+7899', '123+456+789+548', '789+123']}
)# 统计途径路段:123和789的车辆数
data = (data.eval("route=route.str.split('+')").  # 将route拆分成列表# 如果车辆的route包含123和789则flag列赋值为1 否则为0assign(flag=lambda df: df['route'].apply(lambda x: 1 if set(['123', '789']).issubset(set(x)) else 0)).query("flag==1").  # 将flag列为1的数据筛选出来# 比较123和456在列表中的位置assign(order_check=lambda df: df['route'].apply(lambda x: x.index('123') < x.index('789'))).query("order_check==True")
)
data

至此筛选出来了满足条件的车辆,可进一步处理出车辆数。​

clickhouse

select vehicle, splitByChar('+', route) as route_list,  # 将route拆分成数组hasAll(route_list, ['123', '789']) as flag  # 判断['123', '789']是否都包含在route_list中indexOf(route_list, '123') as one,  # 计算123在route_list中的位置indexOf(route_list, '789') as two   # 计算789在route_list中的位置
from table_name
where flag = 1
and one < two

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

相关文章:

  • 从0到1入门系列 | 崖山公开课再加码,三小时带你入门崖山数据库!
  • Powershell自定义带参数的别名
  • 文件操作相关的精讲
  • 05 循环神经网络
  • C#初级——条件判断语句、循环语句和运算符
  • Laravel路由模型绑定:简化依赖注入的艺术
  • 【vue前端项目实战案例】之Vue仿饿了么App
  • 冷热分离——Java全栈知识(36)
  • 了解Selenium中的WebElement
  • OpenCV facedetect 人脸检测官方示例项目配置
  • 自定义Laravel Artisan风格:打造个性化命令行体验
  • CTF之网站被黑
  • Electron学习笔记(一)基础环境
  • 【C语言】栈的实现(数据结构)
  • 前端三大主流框架对比
  • AOP~面向切面编程介绍
  • Android SurfaceFlinger——GraphicBuffer的提交(三十三)
  • 创维汽车滁州永通体验中心开业仪式暨超充车型区域上市会圆满成功
  • 【PHP】系统的登录和注册
  • 2024.7.29 刷题总结
  • WebSocket程序设计
  • ES(ElasticSearch)倒排索引
  • Android Studio Build窗口出现中文乱码问题
  • java生成随机数
  • 动态定制深度学习:Mojo模型与自定义训练算法的无缝切换
  • 昇思25天学习打卡营第19天|DCGAN生成漫画头像
  • 排序题目:按照频率将数组升序排序
  • 实分析与测度论问题的分类
  • 动态代理更改Java方法的返回参数(可用于优化feign调用后R对象的统一处理)
  • Redis缓存数据库进阶——Redis与分布式锁(6)