python中shapefile庫讀取shapefile文件信息
shapefile是GIS中非常重要的一種數(shù)據(jù)類型,在ArcGIS中被稱為要素類(Feature Class),主要包括點(point)、線(polyline)和多邊形(polygon)。Python腳本是ArcGIS官方推薦的腳本語言,通過Python腳本能夠很方便的調(diào)用ArcGIS中的各種工具和函數(shù)批量完成所需操作。本文所介紹的這個庫(Python Shapefile Library)是一個Python庫,用于在Python腳本中對ArcGIS中的Shapefile文件(.shp,.shx,.dbf等格式)進行讀寫操作。
開發(fā)準備
安裝命令:pip install pyshp
使用導(dǎo)入:import shapefile
Shapefile文件的讀操作
通過創(chuàng)建Reader類的對象進行shapefile文件的讀操作。
file = shapefile.Reader('shapefile name')“幾何數(shù)據(jù)”通過Reader類的shapes( )和shape( )方法來讀取,二者的區(qū)別在于:shapes()方法不需要指定參數(shù),其返回值是一個列表,包含該文件中所有的"幾何數(shù)據(jù)"對象,而shape( )方法則需要通過指定參數(shù)返回所需要的"幾何數(shù)據(jù)"對象。
shape = file.shape(i)#讀取第i+1個要素,索引序列從0開始(參數(shù)是整數(shù)類型) shapes = file.shapes()#讀取全部要素
# -*- coding: utf-8 -*-
import shapefile# 使用pyshp
file = shapefile.Reader("E://arcgisData//行政區(qū)劃數(shù)據(jù)//省界_region.shp")#讀取
#讀取元數(shù)據(jù)
print(str(file.shapeType)) # 輸出shp類型
print(file.encoding)# 輸出shp文件編碼
print(file.bbox) # 輸出shp的文件范圍(外包矩形)
print(file.numRecords) # 輸出shp文件的要素數(shù)據(jù)
print(file.fields)# 輸出所有字段信息
# print(file.records()) # 輸出所有屬性表補充 shp類型信息

shp屬性表字段信息
| 字段索引 | 字段類型 |
|---|---|
| C | 字符,文字 |
| N | 數(shù)字,帶或不帶小數(shù) |
| F | 浮動(與“N”相同) |
| L | 邏輯,表示布爾值True / False值 |
| D | 日期 |
| M | 備忘錄,在GIS中沒有意義,而是xbase規(guī)范的一部分 |
展示單個要素
實現(xiàn)代碼:
import shapefile # 使用pyshp
from matplotlib import pyplot as plt
file = shapefile.Reader("E://arcgisData//行政區(qū)劃數(shù)據(jù)//省界_region.shp")
border_shape = file
# 通過創(chuàng)建reader類的對象進行shapefile文件的讀取
# border_points
border = border_shape.shapes()
# .shapes()讀取幾何數(shù)據(jù)信息,存放著該文件中所有對象的 幾何數(shù)據(jù)
# border是一個列表
border_points = border[0].points
print(border_points)# 返回第1個對象的所有點坐標
# border_points = [(x1,y1),(x2,y2),(x3,y3),…]
x, y = zip(*border_points)
# x=(x1,x2,x3,…)
# y=(y1,y2,y3,…)
fig, ax = plt.subplots() # 生成一張圖和一張子圖
# plt.plot(x,y,'k-') # x橫坐標 y縱坐標 ‘k-'線性為黑色
plt.plot(x, y, color='#6666ff', label='fungis') # x橫坐標 y縱坐標 ‘k-'線性為黑色
ax.grid() # 添加網(wǎng)格線
ax.axis('equal')
plt.show()展示效果:

shapefile文件的寫操作
創(chuàng)建點狀要素類
import shapefile # 使用pyshp
file = shapefile.Writer("E://arcgisData//test//站點_2")#新建數(shù)據(jù)存放位置
#創(chuàng)建兩個字段
file.field('FIRST_FLD')
file.field('SECOND_FLD','C','40') #'SECOND_FLD'為字段名稱,C代表數(shù)據(jù)類型為字符串,長度為40
file.point(1,1)
file.record('First','Point')
file.point(300,10)
file.record('Second','Point')
file.point(400,30)
file.record('Third','Point')
file.point(200,200)
file.record('Fourth','Point')
#寫入數(shù)據(jù)
file.close()創(chuàng)建線狀要素類
import shapefile # 使用pyshp
file = shapefile.Writer("E://arcgisData//test//polyline")#新建數(shù)據(jù)存放位置
#創(chuàng)建兩個字段
file.field('FIRST_FLD')
file.field('SECOND_FLD','C','40') #'SECOND_FLD'為字段名稱,C代表數(shù)據(jù)類型為字符串,長度為40
file.line([[[1,5],[5,5],[5,1],[3,3],[1,1]]])
file.record('First','polyline')
file.line([[[1,500],[300,30],[1,16]]])
file.record('Second','polyline')
#寫入數(shù)據(jù)
file.close()創(chuàng)建面狀要素類
import shapefile # 使用pyshp
file = shapefile.Writer("E://arcgisData//test//polygon")#新建數(shù)據(jù)存放位置
#創(chuàng)建兩個字段
file.field('FIRST_FLD')
file.field('SECOND_FLD','C','40') #'SECOND_FLD'為字段名稱,C代表數(shù)據(jù)類型為字符串,長度為40
file.poly([[[1,5],[5,5],[5,1],[3,3],[1,1]]])
file.record('First','polygon')
file.poly([[[1,500],[300,30],[1,16],[1,500]]])
file.record('Second','polygon')
#寫入數(shù)據(jù)
file.close()到此這篇關(guān)于python中shapefile庫讀取shapefile文件信息的文章就介紹到這了,更多相關(guān)python讀取shapefile文件信息內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python設(shè)計模式中的狀態(tài)模式你了解嗎
這篇文章主要為大家詳細介紹了Python設(shè)計模式中的狀態(tài)模式,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助2022-02-02
Python使用Pickle模塊進行數(shù)據(jù)保存和讀取的講解
今天小編就為大家分享一篇關(guān)于Python使用Pickle模塊進行數(shù)據(jù)保存和讀取的講解,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2019-04-04

