folium底图本地化处理

本文涉及的产品
实时数仓Hologres,5000CU*H 100GB 3个月
智能开放搜索 OpenSearch行业算法版,1GB 20LCU 1个月
检索分析服务 Elasticsearch 版,2核4GB开发者规格 1个月
简介: folium底图本地化处理

folium是生成的地图,会连接到开源链接,每次打开生成的地图文件都需要链接到开源链接,有时候会出现地图空白、地图打开链接过慢等问题。

查找原因

分析一下folium生成的地图html文件的源码。

从源码里面能看到有不少外部链接,css和js文件,这些链接都是外网开源的。每次打开html文件都需要缓冲这些外部链接。

解决办法

1.下载css、js文件存放本地

2.生成html文件后,替换原链接

使用re包正则表达式替换原生成的html的链接到本地。

###更新地图,name是地图的地址路桥
def update_mymap(name):
    ###   'mapnew方案1.html'##文件名
    import re
    # 读取生成的HTML文件
    with open(name, 'r',encoding='utf-8') as f:
        html = f.read()
    ###替换链接,r禁止转义,
    rep_dict = {
        r'https://.+/leaflet.js': 'mymap/js/leaflet.js',
        r'https://.+/jquery.+.min.js': 'mymap/js/jquery.min.js',
        r'https://.+/bootstrap.min.js': 'mymap/js/bootstrap.bundle.min.js',
        r'https://.+/bootstrap.bundle.min.js': 'mymap/js/bootstrap.bundle.min.js',
        r'https://.+/leaflet.awesome-markers.js': 'mymap/js/leaflet.awesome-markers.js',
        r'https://.+/leaflet.css': 'mymap/css/leaflet.css',
        r'https://.+css/bootstrap.min.css': 'mymap/css/bootstrap.min.css',
        r'https://.+all.min.css': 'css/all.min.css',
        r'https://.+css/bootstrap-theme.min.css': 'mymap/css/bootstrap-theme.min.css',
        r'https://.+css/font-awesome.min.css': 'mymap/css/fontawesome.min.css',
        r'https://.+/leaflet.awesome-markers.css': 'mymap/css/leaflet.awesome-markers.css',
        r'https://.+/leaflet.awesome.rotate.min.css': 'mymap/css/leaflet.awesome.rotate.css',
        r'https://.+/leaflet.textpath.min.js': 'mymap/js/leaflet.textpath.min.js',
        r'https://.+/leaflet-ant-path.min.js': 'mymap/js/leaflet-ant-path.min.js',
    }
    pattern=list(rep_dict.keys())
    for i in range(len(pattern)):
        html = re.sub(pattern[i],rep_dict[pattern[i]], html)
    # 将修改后的HTML写入新文件
    with open(name, 'w', encoding='utf-8') as f:#w是清空原文件,新的文件替换源文件
        f.write(html)

3.查看新的html文件

链接已经替换到本地了,地图打开很顺利,

目录
相关文章
|
搜索推荐 定位技术
百度地图开发mapStyle个性化地图styleJson的配色解决方案
百度地图开发mapStyle个性化地图styleJson的配色解决方案
639 0
|
定位技术 API 网络架构
地图图层接入:从mapbox转向cesium
由于地图坐标系的不统一,地图图商提供的图层服务也各有特色,在图层对接的开发过程中常会遇到许多坑,从二维图层到三维图层,地图引擎mapbox再到cesium,本文将分享笔者在近期地图图层接入过程中总结的一些经验。
3619 10
|
定位技术
高德地图开发:英文地图的实现方式
高德地图开发:英文地图的实现方式
198 0
|
定位技术
街道社区网格化信息管理Echarts集成百度地图bmap样式表冲突导致的无法显示地图的解决方案
街道社区网格化信息管理Echarts集成百度地图bmap样式表冲突导致的无法显示地图的解决方案
124 0
|
JSON 数据可视化 定位技术
GIS开发:Maputnik地图样式编辑器
GIS开发:Maputnik地图样式编辑器
739 0
|
Java
OFFICE技术讲座:由-(减号)的绘制差异,看不同字体引擎的处理
OFFICE技术讲座:由-(减号)的绘制差异,看不同字体引擎的处理
107 0
OFFICE技术讲座:由-(减号)的绘制差异,看不同字体引擎的处理
OFFICE技术讲座:段落的行是如何布局不同对齐方式的
OFFICE技术讲座:段落的行是如何布局不同对齐方式的
88 0
OFFICE技术讲座:段落的行是如何布局不同对齐方式的
SwiftUI—借助sizeCategory预览不同字体下的文本视图
SwiftUI—借助sizeCategory预览不同字体下的文本视图
157 0
SwiftUI—借助sizeCategory预览不同字体下的文本视图
|
XML 数据采集 搜索推荐
网站地图有什么好处?sitemap地图怎么生成?
网站地图,又称站点地图,可以理解为包含网站中所有页面链接的容器,主要帮助搜索引擎快速抓取网站中的所有页面。很多新人可能对地图了解不够。今天网站地图目录网详细讲讲制作网站地图的好处,以及如何制作Sitemap地图。
网站地图有什么好处?sitemap地图怎么生成?