本身没什么复杂的,主要是处理数据的部分比较繁琐,所以就独立出来写一个了

1 数据集处理

1.1 获取graph

import osmnx as ox
point1=(31.191184,121.516295)
G_=ox.graph_from_point(point1,dist=3000,network_type='drive')
ox.plot_graph(G_)

1.2 转化成GeoDataFrame

nodes_sh,edges_sh=ox.graph_to_gdfs(G_)

python 包介绍:osmnx_UQI-LIUWJ的博客-CSDN博客-6.1

1.3 提取edges_sh中的边

u, v, _ = list(zip(*edges_sh.index))
edges_sh["u"] = u
edges_sh["v"] = v
#这样的话edges_sh 中就会有u和v 两列了edges_sh['id']=np.arange(edges_sh.shape[0])
edges_sh.set_index('id',inplace=True)
#修改索引列edges_sh.drop(['oneway','highway','ref','bridge','lanes','maxspeed','geometry','tunnel'],axis=1,inplace=True)
#丢弃一些暂时不用到的边

1.4 随机生成路线

route_=[63328951]
#表示初始的点
for i in range(1000):try:route_.append(np.random.permutation(edges_sh[edges_sh['u']==route_[-1]]['v'].values)[0])except:break#u是起点,v是终点,每一次将上一个终点作为下一个起点#这里用try-except的意思是,如果到了边界,那么就不会有下一条u-v边了,结束route的更新

2 plot_graph_route

2.1 基本使用方法

osmnx.plot.plot_graph_route(G, route, route_color='r', route_linewidth=4, route_alpha=0.5, orig_dest_size=100, ax=None, **pg_kwargs)

2.2 参数说明

G (networkx.MultiDiGraph) 输入图
route (list) 点id组成的list
route_color (string 路线的颜色
route_linewidth (int 路线的宽度
route_alpha (float) 路线的透明度
orig_dest_size (int 起止点的大小
ax 图像的轴

2.3 使用举例

ox.plot.plot_graph_route(G_,route_,route_color='green',route_linewidth=5,route_alpha=0.5,orig_dest_size=500,figsize=(50,20))

终点在图的边缘处,没有下一条边了(事实上这个route也只有五百多条边)。

这也就是之前使用try语句的原因。

3 plot_graph_routes

3.1 基本使用方法

osmnx.plot.plot_graph_routes(G, routes, route_colors='r', route_linewidths=4, **pgr_kwargs)

3.2 参数介绍

G (networkx.MultiDiGraph) 输入的图
routes (list) route的list
route_colors (string or list)

如果是string的话,就是所有的路径使用相同的颜色

如果是list的话,就是不同的路径不同的颜色

route_linewidths (int or list)

如果是int的话,就是所有的路径使用相同的宽度

如果是list的话,就是不同的路径不同的宽度

3.3 使用举例

route_list=[]
#route的集合
for _ in range(5):route_=[np.random.choice(nodes_sh.index.values)]#表示初始的点for i in range(1000):try:route_.append(np.random.permutation(edges_sh[edges_sh['u']==route_[-1]]['v'].values)[0])except:breakroute_list.append(route_)
ox.plot.plot_graph_routes(G_,route_list,route_colors=['green','red','purple','blue','orange'],route_linewidths=5,figsize=(50,20))

osmnx 笔记: plot_graph_route plot_graph_routes相关推荐

  1. osmnx 补充笔记:get_edge_colors_by_attr get_node_colors_by_attr

    0 数据部分 与osmnx 笔记: plot_graph_route & plot_graph_routes_UQI-LIUWJ的博客-CSDN博客 中1.1,1.2一致 edges_sh[' ...

  2. python 包介绍:osmnx

    1 osmnx介绍 一个Python 包,可检索.建模.分析和可视化来自 OpenstreetMap 的街道网络. 2 graph模块 graph类型就是networkx 包中的graph类型.所以p ...

  3. python库整理目录

     zip与zip(*)_刘文巾的博客-CSDN博客 python函数整理_刘文巾的博客-CSDN博客 python笔记:正则表达式_刘文巾的博客-CSDN博客 python笔记:深拷贝与浅拷贝_刘文巾 ...

  4. 【读书笔记】知易行难,多实践

    前言: 其实,我不喜欢看书,只是喜欢找答案,想通过专业的解答来解决我生活的困惑.所以,我听了很多书,也看了很多书,但看完书,没有很多的实践,导致我并不很深入在很多时候. 分享读书笔记: <高效1 ...

  5. 【运维学习笔记】生命不息,搞事开始。。。

    001生命不息,搞事不止!!! 这段时间和hexesdesu搞了很多事情! 之前是机械硬盘和固态硬盘的测速,我就在那默默的看着他一个硬盘一个机械测来测去. 坐在他后面,每天都能看到这位萌萌的小男孩,各 ...

  6. SSAN 关系抽取 论文笔记

    20210621 https://zhuanlan.zhihu.com/p/353183322 [KG笔记]八.文档级(Document Level)关系抽取任务 共指id嵌入一样 但是实体嵌入的时候 ...

  7. pandas以前笔记

    # -*- coding: utf-8 -*- """ Created on Sat Jul 21 20:06:20 2018@author: heimi "& ...

  8. PyTorch 学习笔记(六):PyTorch hook 和关于 PyTorch backward 过程的理解 call

    您的位置 首页 PyTorch 学习笔记系列 PyTorch 学习笔记(六):PyTorch hook 和关于 PyTorch backward 过程的理解 发布: 2017年8月4日 7,195阅读 ...

  9. 容器云原生DevOps学习笔记——第三期:从零搭建CI/CD系统标准化交付流程

    暑期实习期间,所在的技术中台-效能研发团队规划设计并结合公司开源协同实现符合DevOps理念的研发工具平台,实现研发过程自动化.标准化: 实习期间对DevOps的理解一直懵懵懂懂,最近观看了阿里专家带 ...

最新文章

  1. 1.5亿美元!英国AI芯片创企今宣布获新融资,估值近20亿美元
  2. mysql的count(*)的优化,获取千万级数据表的总行数
  3. YII1 MVC初认识(二)
  4. wps文字退格会删掉文字_WPS第二行文字前面有大量空白,按退格不会动,只是把上一行末尾的字去掉。...
  5. python字符串替换空格_python - 用pandas中的NaN替换空白值(空格)
  6. 第四范式完成C+轮融资,估值约20亿美元
  7. 如何能出令自己满意的代码
  8. UVA - 101:The Blocks Problem
  9. JAVA工具类-StrUtils
  10. 【干货】2021短视频营销攻略:短视频内容策略下的5i沟通法则.pdf(附下载链接)...
  11. 力扣 O(1) 时间插入、删除和获取随机元素 - 允许重复
  12. 关于style设置方法,obj.setAttribute(style.)和obj.style.stylename
  13. 项目常用工具类整理(一)--时间工具类DateUtil.java
  14. 网管学习日记-STP
  15. wps的range对象
  16. 微型计算机补码运算电路特点,二进制数的运算及其加法电路
  17. 投资理财里的必然和概率
  18. Casbin-authz-plugin:基于Casbin的Docker权限管理、访问控制插件
  19. MPLS LDP基础
  20. 榴莲核的作用和功效有哪些

热门文章

  1. UIAppearanceContainer 利器
  2. Spring4.1新特性——Spring MVC增强
  3. 华为机考回忆版(三:自己的)
  4. 《Android学习指南》目录
  5. 合并多个Word文档
  6. 梯度下降法及其Python实现
  7. java课程 数独 文库_数独java
  8. java 7zip解压_Apache Commons Compress介绍-JAVA压缩解压7z文件
  9. DualCircleList
  10. Qt基于文本协议的网络应用开发