perl 传单引号_使用geopandas和传单在python和r中绘制精美的地理图

本文主要是介绍perl 传单引号_使用geopandas和传单在python和r中绘制精美的地理图,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

perl 传单引号

There are several geographic libraries that are available for plotting location information on a map. I’ve previously written about the same topic here but since then I’ve used these libraries more extensively as well as got introduced to new ones. After using and examining several libraries, I found that GeoPandas and the Leaflet libraries are two of the most easy to use and highly customizable libraries. The code is available as a GitHub repo:

有几个地理库可用于在地图上绘制位置信息。 我以前在这里曾写过同一主题,但是从那时起,我就更广泛地使用了这些库,并且将它们引入了新库。 使用并检查了几个库之后,我发现GeoPandas和Leaflet库是最易于使用和高度可定制的两个库。 该代码可作为GitHub存储库提供:

数据集 (Dataset)

The dataset is taken from Kaggle. It includes the population density (population per square Km) for various countries across the world. The dataset includes the values ranging from 1961 to 2015.

该数据集取自Kaggle 。 它包括世界各国的人口密度(每平方千米人口)。 数据集包括从1961年到2015年的值。

Image for post
Dataset
数据集

The figure above shows that we need to skip the first 4 rows when reading in the dataset, so we directly start with the data. Columns such as “1960” are empty and hence they can be removed. Also, data for some countries like Belgium is missing so we’ll remove these records from our collection.

上图显示,在读取数据集时,我们需要跳过前4行,因此我们直接从数据开始。 诸如“ 1960”的列为空,因此可以将其删除。 另外,某些国家(例如比利时)的数据丢失了,因此我们将从集合中删除这些记录。

使用GeoPandas的静态图(在Python中) (Static plots using GeoPandas (in Python))

导入库 (Import libraries)

We’ll import the library pandas to read the dataset and then plot the maps using geopandas. Note that to remove unnecessary warnings, I added the specific command.

我们将导入库pandas以读取数据集,然后使用geopandas绘制地图。 请注意,为消除不必要的警告,我添加了特定命令。

import pandas as pd
import geopandas as gpdimport warnings
warnings.filterwarnings('ignore')%matplotlib inline

导入数据集(Import dataset)

Next, we’ll import the dataset. As mentioned before, I skip the first 4 rows.

接下来,我们将导入数据集。 如前所述,我跳过了前4行。

dataset = pd.read_csv("data/dataset.csv", skiprows=4)
dataset = dataset.drop(["Indicator Name", "Indicator Code", "1960", "2016", "Unnamed: 61"], axis = 1)
dataset = dataset.dropna(how = 'any')
dataset["avgPopulationDensity"] = dataset.iloc[:, 2:].mean(axis = 1)
dataset.head()

I remove all the extra columns that I don’t need (“Indicator Name”, “Indicator Code”, “1960”, “2016”, “Unnamed: 61”) using the drop() method. I remove all records with any NULL values using dropna()and finally calculate the average population density across years 1961 to 2015 into a new column avgPopulationDensity.

我使用drop()方法删除了所有不需要的额外列(“指标名称”,“指标代码”,“ 1960”,“ 2016”,“未命名:61”)。 我使用dropna()删除所有具有任何NULL值的记录,最后将1961年至2015年之间的平均人口密度计算到新列avgPopulationDensity

Image for post
Resulting dataset
结果数据集

绘图数据(Plot data)

We first load in the world baseplot directly from geopandas and then merge the dataset we refined above with this baseplot data. Then, we simply plot th data world shaded by the values in the avgPopulationDensity column. We shade the countries in the Reds colormap which means countries with higher average population densities are darker than other countries.

我们首先直接从geopandas加载世界基准图,然后将我们在上面精炼的数据集与此基准图数据合并。 然后,我们简单地绘制由avgPopulationDensity列中的值阴影的数据world 。 我们在“ Reds配色图中为国家/地区加阴影,这意味着平均人口密度较高的国家/地区比其他国家更暗。

world = gpd.read_file(gpd.datasets.get_path('naturalearth_lowres'))
world = world.merge(dataset, how = 'left', left_on = 'iso_a3', right_on = 'Country Code')
world.plot(column = 'avgPopulationDensity', edgecolor = 'black',figsize = (16, 16),cmap = 'Reds')
Image for post
Average Population Density plot (using GeoPandas)
平均人口密度图(使用GeoPandas)

We can clearly see that countries in Asia have more population density values especially India, Bangladesh, Korea and Japan.

我们可以清楚地看到,亚洲国家的人口密度值更高,尤其是印度,孟加拉国,韩国和日本。

使用Leaflet的交互式图(在R中) (Interactive plots using Leaflet (in R))

导入库 (Import libraries)

We’ll load in the leaflet library for generating plots and the sf library for reading in shapefiles.

我们将加载用于生成图形的leaflet库,并加载用于读取shapefile的sf库。

library(leaflet)
library(sf)

导入数据集(Import dataset)

Just like in Python, we’d import in the dataset skipping first 4 rows, remove extra columns, remove rows with missing values and create the avgPopulationDensity column.

就像在Python中一样,我们将跳过前4行导入数据集中,删除多余的列,删除缺少值的行并创建avgPopulationDensity列。

dataset <- read.csv("data/dataset.csv", skip = 4)
dataset[, c("Indicator.Name", "Indicator.Code", "X1960", "X2016", "X")] <- NULL
dataset <- dataset[complete.cases(dataset), ]
dataset["avgPopulationDensity"] <- rowSums(dataset[,3:57])

It’s important that we also load in the shapefile needed for the plotting. Thus, we use the st_read method and merge the dataset with this shapefile into a variable named shapes.

重要的是,我们还要加载绘图所需的shapefile。 因此,我们使用st_read方法并将具有此shapefile的数据集合并到一个名为shapes的变量中。

shapes <- st_read("data/countries_shp/countries.shp")
shapes <- merge(shapes, dataset, by.x = 'ISO3', by.y = 'Country.Code')

绘图数据(Plot data)

Before we plot the data, we first define the color palette we want to use. I defined the shades of red for various bins and based on that I will shade the resultant plot. As this is a custom palette, it’s colors will be different from the one we see in the GeoPandas plot.

在绘制数据之前,我们首先定义要使用的调色板。 我为各种垃圾箱定义了红色阴影,并以此为基础绘制了结果图。 由于这是一个自定义调色板,因此其颜色将与我们在GeoPandas图中看到的颜色不同。

colors <- c("#8B0000","#FF0000", "#FFA07A")
bins <- c(100000, 20000, 5000, 0)color_pal <- leaflet::colorBin(colors, domain = shapes$avgPopulationDensity, bins = bins)

Next, we plot the leaflet geoplot. The leaflet() starts creating the plot and addTiles() adds the tiles for the countries. Next, we set the view of the map by defining the latitude and longitude values as well as the zoom so we can see the whole map at once. We can change the values if needed but as it is an interactive map, we can do so dynamically too.

接下来,我们绘制传单地理图。 leaflet()开始创建图, addTiles()添加国家/地区的图块。 接下来,我们通过定义纬度和经度值以及缩放比例来设置地图视图,以便我们可以一次查看整个地图。 我们可以根据需要更改值,但由于它是一个交互式地图,因此也可以动态更改。

leaflet(shapes) %>% addTiles() %>%setView(lat = 10, lng = 0, zoom = 1) %>%addPolygons(fillColor = ~color_pal(shapes$avgPopulationDensity),fillOpacity = 0.7,label = shapes$Country.Name,stroke = TRUE,color = 'black',weight = 1,opacity = 1)

Finally, based on the avgPopulationDensity column, we color grade the whole plot and attach country names as labels. We customize the look of each country by adding in strokes (STROKE = TRUE), and then setting them to be black with weight = 1, defining the width of each boundary.

最后,基于avgPopulationDensity列,我们对整个绘图进行颜色分级,并附加国家名称作为标签。 我们通过添加笔画( STROKE = TRUE ),然后将它们设置为weight = 1 black ,定义每个边界的宽度,来自定义每个国家/地区的外观。

Image for post
Average Population Density plot (using LeafLet)
平均人口密度图(使用LeafLet)

We observe that countries in Asia like India, Bangladesh, China, Japan and others have high population densities than other countries.

我们观察到,印度,孟加拉国,中国,日本等亚洲国家的人口密度比其他国家高。

结论 (Conclusion)

From the two examples above, we see how easy it is to create beautiful static and dynamic geographic plots. Plus, there are tons of customizations that we can add.

从上面的两个示例中,我们看到了创建漂亮的静态和动态地理图非常容易。 另外,我们可以添加大量自定义设置。

If you have any suggestions, questions or ideas, please let me know down below.

如果您有任何建议,问题或想法,请在下面告诉我。

翻译自: https://towardsdatascience.com/elegant-geographic-plots-in-python-and-r-using-geopandas-and-leaflet-27126b60bace

perl 传单引号


http://www.taodudu.cc/news/show-7943204.html

相关文章:

  • java-IO流中的对象流和序列化理解
  • Node.js(尚硅谷最经典Node.js快速入门学习笔记)
  • 单片机缩写
  • 语音低速率编码技术和数字水印技术的研究
  • 无线网络和技术概念
  • 【专业造轮子】:一位大神的编程之路,让我大吃一惊!
  • Lombok注解@SneakyThrows的作用
  • 电池模拟器之电阻分压1
  • 杰里之693N 纽扣电池供电(硬件有特殊接法--自行对原理图【篇】
  • 电池BMS电流校准原理
  • 电池级碳酸锂、碳酸氢锂除钙镁的工作原理
  • 动力电池原理说明及应用概述
  • 电池工作原理:一种通俗易懂的讲解
  • 【操作系统】总结 (一) 计组部分知识
  • 云网融合,SDN在云数据中心的应用
  • 可口的故事
  • linux下安装qt、qt触摸屏校准tslib
  • 锐捷网络:缔造创新型无线WiFi
  • 系统设计时如何应对现今主流的攻击?
  • 细节选择成功——谈中小企业网站建设之网络营
  • 案例分享:广深沿江高速已部署93根多功能智能杆
  • Gartner:2021-2022年八大网络安全预测
  • 主机加固:系统加固的新概念
  • 网络安全如何解决攻防不对等和系统碎片化危机?
  • 利用网络安全路线图实现IT合规
  • 卷积神经网络与视觉计算,卷积神经网络的可视化
  • 人工神经网络与神经网络,完整的人工神经网络
  • Springboot 异步任务@Async 使用和失效分析
  • ESD与EOS失效案例分享
  • MYSQL索引使用案例分析
  • 这篇关于perl 传单引号_使用geopandas和传单在python和r中绘制精美的地理图的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



    http://www.chinasem.cn/article/202118

    相关文章

    Java调用Python的四种方法小结

    《Java调用Python的四种方法小结》在现代开发中,结合不同编程语言的优势往往能达到事半功倍的效果,本文将详细介绍四种在Java中调用Python的方法,并推荐一种最常用且实用的方法,希望对大家有... 目录一、在Java类中直接执行python语句二、在Java中直接调用Python脚本三、使用Run

    使用Python开发Markdown兼容公式格式转换工具

    《使用Python开发Markdown兼容公式格式转换工具》在技术写作中我们经常遇到公式格式问题,例如MathML无法显示,LaTeX格式错乱等,所以本文我们将使用Python开发Markdown兼容... 目录一、工具背景二、环境配置(Windows 10/11)1. 创建conda环境2. 获取XSLT

    Python如何调用指定路径的模块

    《Python如何调用指定路径的模块》要在Python中调用指定路径的模块,可以使用sys.path.append,importlib.util.spec_from_file_location和exe... 目录一、sys.path.append() 方法1. 方法简介2. 使用示例3. 注意事项二、imp

    PyQt5+Python-docx实现一键生成测试报告

    《PyQt5+Python-docx实现一键生成测试报告》作为一名测试工程师,你是否经历过手动填写测试报告的痛苦,本文将用Python的PyQt5和python-docx库,打造一款测试报告一键生成工... 目录引言工具功能亮点工具设计思路1. 界面设计:PyQt5实现数据输入2. 文档生成:python-

    Python中Flask模板的使用与高级技巧详解

    《Python中Flask模板的使用与高级技巧详解》在Web开发中,直接将HTML代码写在Python文件中会导致诸多问题,Flask内置了Jinja2模板引擎,完美解决了这些问题,下面我们就来看看F... 目录一、模板渲染基础1.1 为什么需要模板引擎1.2 第一个模板渲染示例1.3 模板渲染原理二、模板

    浅析如何使用xstream实现javaBean与xml互转

    《浅析如何使用xstream实现javaBean与xml互转》XStream是一个用于将Java对象与XML之间进行转换的库,它非常简单易用,下面将详细介绍如何使用XStream实现JavaBean与... 目录1. 引入依赖2. 定义 JavaBean3. JavaBean 转 XML4. XML 转 J

    使用Python创建一个功能完整的Windows风格计算器程序

    《使用Python创建一个功能完整的Windows风格计算器程序》:本文主要介绍如何使用Python和Tkinter创建一个功能完整的Windows风格计算器程序,包括基本运算、高级科学计算(如三... 目录python实现Windows系统计算器程序(含高级功能)1. 使用Tkinter实现基础计算器2.

    在.NET平台使用C#为PDF添加各种类型的表单域的方法

    《在.NET平台使用C#为PDF添加各种类型的表单域的方法》在日常办公系统开发中,涉及PDF处理相关的开发时,生成可填写的PDF表单是一种常见需求,与静态PDF不同,带有**表单域的文档支持用户直接在... 目录引言使用 PdfTextBoxField 添加文本输入域使用 PdfComboBoxField

    Git可视化管理工具(SourceTree)使用操作大全经典

    《Git可视化管理工具(SourceTree)使用操作大全经典》本文详细介绍了SourceTree作为Git可视化管理工具的常用操作,包括连接远程仓库、添加SSH密钥、克隆仓库、设置默认项目目录、代码... 目录前言:连接Gitee or github,获取代码:在SourceTree中添加SSH密钥:Cl

    Python开发文字版随机事件游戏的项目实例

    《Python开发文字版随机事件游戏的项目实例》随机事件游戏是一种通过生成不可预测的事件来增强游戏体验的类型,在这篇博文中,我们将使用Python开发一款文字版随机事件游戏,通过这个项目,读者不仅能够... 目录项目概述2.1 游戏概念2.2 游戏特色2.3 目标玩家群体技术选择与环境准备3.1 开发环境3