使用matplotlib查看从shapefile读取的多边形

时间:2012-06-03 14:20:10

标签: matplotlib shapefile

我正在尝试使用matplotlib和pyshp查看从Shapefile读取的基本多边形 但我所有的努力只产生一个没有多边形的空轴。以下是我的一些尝试,使用显示borders of Belgium的数据集:

import shapefile as sf
r = sf.Reader("BEL_adm/BEL_adm0")
p=r.shapes()
b=p[0]
points = b.points

import matplotlib.pyplot as plt
from matplotlib.path import Path
imporst matplotlib.patches as patches

verts = points

verts = []
for x,y in points:
    verts.append(tuple([x,y]))

codes = ['']*len(verts)
codes[0] = Path.MOVETO
codes[-1] = Path.CLOSEPOLY

for i in range(1,len(verts)):
    codes[i]=Path.LINETO

path = Path(verts, codes)
fig = plt.figure()
ax = fig.add_subplot(111)
patch = patches.PathPatch(path, facecolor='orange', lw=2)
ax.add_patch(patch)
ax.set_xlim(-2,2)
ax.set_ylim(-2,2)
plt.show()

使用补丁的另一次尝试也会产生一个空框架:

fig = plt.figure(figsize=(11.7,8.3))

ax = plt.subplot(111)
x,y=zip(*b.points)
import matplotlib.patches as patches
import matplotlib.pyplot as plt
bol=patches.Polygon(b.points,True, transform=ax.transAxes)

ax.add_patch(bol)
ax.set_ylim(0,60)
ax.set_xlim(0,200)
plt.show()

很高兴看到我所缺少的东西 谢谢,奥兹

1 个答案:

答案 0 :(得分:1)

而不是调用set_xlim(), set_ylim()来设置轴的范围,您可以使用ax.autoscale()

对于您的Polygon版本,您不需要将transform参数设置为ax.transAxes,只需调用:

bol=patches.Polygon(b.points,True)