我们可以使用Basemap这个工具包来实现中国地图的绘制
首先需要加载一些包:
import numpy as np import matplotlib.pyplot as plt from mpl_toolkits.basemap import Basemap
Basemap包就是气象画图的利器,现在我们就可以愉快的画图了!
plt.figure(1) map=Basemap() map.drawcoastlines() plt.title(r'$World\ Map$',fontsize=24) plt.show()
第2行创建一个地图,第3行添加海岸线,这样一个世界地图就出来了,怎么样,很简单吧。(plt.show()这行代码是用来显示图片的)
我们发现这只是海岸线图,那么怎么将国界线添加上去呢?很简单,只要添加一行代码就可以了。
map.drawcountries()
那么怎么添加河流呢?可能有些同学已经猜到了,就是drawrivers()
map.drawrivers(color='blue',linewidth=0.3)
好了,现在我们可以开始画中国地图了!
其实只要在创建地图时指定一下范围就可以了,查阅资料发现,中国的经纬度范围是东经135度2分30秒-东经73度40分,北纬3度52分-北纬53度33分。
map=Basemap(llcrnrlon=70,llcrnrlat=3,urcrnrlon=139,urcrnrlat=54)
好了,一个中国地图就出来了!但是我们发现,好像少了点什么,没错就是省界。我们可以在https://gadm.org/download_country_v3.html下载中国大陆和台湾省的行政区域的shape文件,下载后解压,然后加入下面的代码。
CHN='G:\python_material\MapOfChina'
CHN的值就是解压后的地图文件所在的地址。
下面我们就可以加入省界了!
map.readshapefile(CHN+'\gadm36_CHN_shp\gadm36_CHN_1', 'states',drawbounds=True)
别忘了把台湾省加上去
map.readshapefile(CHN+'\gadm36_TWN_shp\gadm36_TWN_1', 'taiwan',drawbounds=True)
还可以在地图上加上经纬度,比如我们要画5条经纬线,可以这么做:
parallels = np.linspace(3,55,5) map.drawparallels(parallels,labels=[True,False,False,False]) meridians = np.linspace(70,140,5) map.drawmeridians(meridians,labels=[False,False,False,True])
大功告成!但是,emmm,我们发现好像有点歪?我们可以在创建地图时选择投影参数。
map=Basemap(llcrnrlon=70,llcrnrlat=3,urcrnrlon=137,urcrnrlat=54, projection = 'lcc', lat_1 = 33, lat_2 = 45, lon_0 = 100)
这回正式的完成了!
附上所有代码:
import numpy as np import matplotlib.pyplot as plt from mpl_toolkits.basemap import Basemap plt.figure(1) map=Basemap(llcrnrlon=70,llcrnrlat=3,urcrnrlon=139,urcrnrlat=54, projection = 'lcc', lat_1 = 33, lat_2 = 45, lon_0 = 100) map.drawcoastlines() map.drawcountries() map.drawrivers(color='blue',linewidth=0.3) CHN='G:\python_material\MapOfChina' map.readshapefile(CHN+'\gadm36_CHN_shp\gadm36_CHN_1', 'states',drawbounds=True) map.readshapefile(CHN+'\gadm36_TWN_shp\gadm36_TWN_1', 'taiwan',drawbounds=True) parallels = np.linspace(3,55,5) map.drawparallels(parallels,labels=[True,False,False,False]) meridians = np.linspace(70,140,5) map.drawmeridians(meridians,labels=[False,False,False,True]) plt.title(r'$China\ Map$',fontsize=24) plt.show()
以上就是利用python绘制中国地图的详细内容,更多关于python 绘制地图的资料请关注其它相关文章!
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新日志
- 【雨果唱片】中国管弦乐《鹿回头》WAV
- APM亚流新世代《一起冒险》[FLAC/分轨][106.77MB]
- 崔健《飞狗》律冻文化[WAV+CUE][1.1G]
- 罗志祥《舞状元 (Explicit)》[320K/MP3][66.77MB]
- 尤雅.1997-幽雅精粹2CD【南方】【WAV+CUE】
- 张惠妹.2007-STAR(引进版)【EMI百代】【WAV+CUE】
- 群星.2008-LOVE情歌集VOL.8【正东】【WAV+CUE】
- 罗志祥《舞状元 (Explicit)》[FLAC/分轨][360.76MB]
- Tank《我不伟大,至少我能改变我。》[320K/MP3][160.41MB]
- Tank《我不伟大,至少我能改变我。》[FLAC/分轨][236.89MB]
- CD圣经推荐-夏韶声《谙2》SACD-ISO
- 钟镇涛-《百分百钟镇涛》首批限量版SACD-ISO
- 群星《继续微笑致敬许冠杰》[低速原抓WAV+CUE]
- 潘秀琼.2003-国语难忘金曲珍藏集【皇星全音】【WAV+CUE】
- 林东松.1997-2039玫瑰事件【宝丽金】【WAV+CUE】