[OSGeoJapan-discuss] QGISのpythonコンソールで面積を計算してその結果を列に加える方法

Taro Matsuzawa taro @ georepublic.co.jp
2015年 5月 20日 (水) 19:31:26 PDT


松澤です。

この手のものはもしPythonを使うならQGISよりも
ogrで直接処理したほうがよいのかなと思います。
ipythonとか使えばデバッグも楽ですし、
何よりQGISのビルドがコケて環境破壊した時でも使えます。
# MacPortsあるあるなのでWindowsならそんな事起きないと思うけど

1. 面積計算
https://pcjericks.github.io/py-gdalogr-cookbook/geometry.html#calculate-the-area-of-a-geometry
2. Shapefileに属性テーブルを追加してデータを投入する例
https://pcjericks.github.io/py-gdalogr-cookbook/vector_layers.html#create-a-new-shapefile-and-add-data
(新規でファイル作ってるけど、やってることは同じだと思う)

これらの組み合わせでいける気がします。
あと、Pythonでは他にもいろいろライブラリがあるみたいなので、
探してみるとよいかもしれません。

On 2015/05/21 11:12, Hayato IIJIMA wrote:
> 今木様、皆様
> 
> 山梨県の飯島です。早速のお返事ありがとうございました。
> 
> こんなパッケージがあるとは知りませんでした。Rでできるならその方が得意なので、ありがたいです。早速試してみます。
> 
> 他の皆様も別な技をご存知でしたら、よろしくお願いします。
> 
> 
> 2015年5月21日 10:45 Hiroo Imaki <hiroo @ angeli.org>:
>> 飯島様、
>> お久しぶりです。Rでやっても良いのではないでしょうか?http://www.inside-r.org/packages/cran/rgeos/docs/gArea が参考になると思います。spパッケージを使ってオブジェクトを作る必要がありますが。
>> 参考までに。
>> いまき
>>
>> 2015-05-20 19:48 GMT-04:00 Hayato IIJIMA <hayato.iijima @ gmail.com>:
>>>
>>> OSGeoメーリングリストの皆様
>>>
>>> 山梨県の飯島と申します。このたびはお世話になります。
>>>
>>>
>>> QGISのpythonコンソールで、SHPファイル(添付したようなファイル)のポリゴンごとの面積を計算する方法をご存知でしたら、ご教示いただければと思います。
>>>
>>>
>>> ファイルが1つであればSHPファイルを開き、「属性テーブルを開く」→「フィールド計算機」で新しい列を作りその値として計算した面積を入れればいい話です。しかし、このようなファイルが多数ある場合、GUIによる作業は時間がかかるため、pythonで一気に処理できないかと思っています。
>>>
>>>
>>> ネット上でQGISのpythonでの処理方法をいろいろ調べてみて、面積を計算して単に表示するとか、新しい列を作るといったことはできるのですが、面積を計算してその結果を新しい列に加えるということがどうしてもできないのです。
>>>
>>> from PyQt4.QtCore import *
>>> from qgis.analysis import *
>>> input_dir="C:/..." #作業するSHPファイルまでのパス
>>> import os
>>> import glob
>>> import processing
>>> files = glob.glob(os.path.join(input_dir, r'*.shp'))
>>>
>>> #面積を「表示」
>>> for i in range(0, len(files)):
>>> vlayer = QgsVectorLayer(files[i], "temp", "ogr")
>>> #Gmail上でタブによる字下げがうまくいきませんが、実際にはタブで行頭を字下げしています(以下同様)。
>>> for f in vlayer.getFeatures():
>>> print f.geometry().area()
>>>
>>> #新しい列を加える
>>> #カラムを加える(試行錯誤)
>>> for i in range(0, len(files)):
>>> vlayer = QgsVectorLayer(files[i], "temp", "ogr")
>>> #Gmail上でタブによる字下げがうまくいきませんが、実際にはタブで行頭を字下げしています(以下同様)。
>>> caps = vlayer.dataProvider().capabilities()
>>> if caps & QgsVectorDataProvider.AddFeatures:
>>> res = vlayer.dataProvider().addAttributes([QgsField("AREA",
>>> QVariant.Double)])
>>>
>>> これらを合わせるとうまくいきそうな気もしますが、今のところできていません。
>>> ちなみに、作業環境は以下のようです。
>>>
>>> OS: Win7 64 bit
>>> QGIS: 2.8
>>>
>>> 調査に出ているためご教示いただいた後の返事が遅くなるかもしれませんが、よろしくお願い致します。
>>>
>>>
>>> --
>>> **********************************************************
>>> 山梨県森林総合研究所 森林研究部 森林保護科
>>>
>>> 研究員  飯島 勇人(いいじま はやと)
>>>
>>> 〒400-0502
>>> 山梨県南巨摩郡富士川町最勝寺2290-1
>>> TEL:0556-22-8005(直)8001(代)
>>> HP: http://www.pref.yamanashi.jp/shinsouken/
>>> E-mail: hayato.iijima @ gmail.com
>>> **********************************************************
>>>
>>> **********************************************************
>>> Hayato Iijima (Ph.D.)
>>>
>>> Yamanashi Forest Research Institute
>>>
>>> 2290-1, Saishoji, Fujikawa, Yamanashi 400-0502, Japan
>>> TEL:0556-22-8001
>>> HP: http://www.pref.yamanashi.jp/shinsouken/
>>> E-mail: hayato.iijima @ gmail.com
>>> **********************************************************
>>>
>>> _______________________________________________
>>> OSGeoJapan-discuss mailing list
>>> OSGeoJapan-discuss @ lists.osgeo.org
>>> http://lists.osgeo.org/mailman/listinfo/osgeojapan-discuss
>>
>>
>>
>>
>> --
>> Hiroo Imaki
>> Pacific Spatial Solutions, LLC
>> 1523 Chatham Colony Ct.
>> Reston, VA  20190
>> hiroo.imaki @ pacificspatial.com
>> http://www.pacificspatial.com
>> http://www.geopacific.org (GIS info site)
>> hiroo @ angeli.org (private)
>>
> 
> 
> 


-- 
Taro Matsuzawa
Georepublic Japan
mail: taro @ georepublic.co.jp
web: http://georepublic.co.jp


OSGeoJapan-discuss メーリングリストの案内