{"id":231,"date":"2024-04-13T20:03:59","date_gmt":"2024-04-13T11:03:59","guid":{"rendered":"https:\/\/www.flumen-jp.com\/wordpress\/?p=231"},"modified":"2025-07-29T16:50:30","modified_gmt":"2025-07-29T07:50:30","slug":"ogr2ogr_2","status":"publish","type":"post","link":"https:\/\/www.flumen-jp.com\/wordpress\/index.php\/2024\/04\/13\/ogr2ogr_2\/","title":{"rendered":"CUI \u3067 GIS (2)"},"content":{"rendered":"\n<p>\u3000<a href=\"https:\/\/www.flumen-jp.com\/wordpress\/index.php\/2024\/04\/12\/ogr2ogr\/\">\u524d\u56de<\/a>\u306b\u5f15\u304d\u7d9a\u304d\u3001<strong>ogr2ogr<\/strong> \u306e\u7d39\u4ecb\u3067\u3059\u3002<br>\u3000\u4eca\u56de\u306f\u4e0b\u306b\u793a\u3059\u56db\u56fd 4 \u770c\u306e\u770c\u5e81\u6240\u5728\u5730\u306e\u5730\u56f3\u3092\u4f5c\u6210\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<figure class=\"wp-block-image size-full\"><img loading=\"lazy\" decoding=\"async\" width=\"887\" height=\"719\" src=\"https:\/\/www.flumen-jp.com\/wordpress\/wp-content\/uploads\/2024\/04\/shikoku.png\" alt=\"\" class=\"wp-image-232\" srcset=\"https:\/\/www.flumen-jp.com\/wordpress\/wp-content\/uploads\/2024\/04\/shikoku.png 887w, https:\/\/www.flumen-jp.com\/wordpress\/wp-content\/uploads\/2024\/04\/shikoku-300x243.png 300w, https:\/\/www.flumen-jp.com\/wordpress\/wp-content\/uploads\/2024\/04\/shikoku-768x623.png 768w\" sizes=\"auto, (max-width: 887px) 100vw, 887px\" \/><\/figure>\n\n\n\n<p>\u3000\u4eca\u56de\u4f7f\u7528\u3057\u305f\u5143\u30c7\u30fc\u30bf\u306f\u6b21\u306e 2 \u70b9\u3067\u3059\u3002<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li><a href=\"https:\/\/www.esrij.com\/products\/japan-shp\/\">\u5168\u56fd\u5e02\u533a\u753a\u6751\u754c\u30c7\u30fc\u30bf<\/a><\/li>\n\n\n\n<li><a href=\"https:\/\/opendata-web.site\/static\/top\/dl\/ad\/office_latlon_pref_utf8_20180611.zip\">\u770c\u5e81\u306e\u7def\u5ea6\u7d4c\u5ea6\u30c7\u30fc\u30bf<\/a><\/li>\n<\/ul>\n\n\n\n<p>\u3000\u3044\u304d\u306a\u308a\u3067\u3059\u304c\u3001\u3053\u308c\u3089\u306e\u30c7\u30fc\u30bf\u304b\u3089\u4e3b\u984c\u56f3\u3092\u4f5c\u308b\u305f\u3081\u306e\u30d0\u30c3\u30c1\u30d5\u30a1\u30a4\u30eb\u306f\u6b21\u306e\u3088\u3046\u306b\u306a\u308a\u307e\u3059\u3002\u524d\u56de\u3068\u540c\u69d8\u306e\u30b3\u30de\u30f3\u30c9\u30e9\u30a4\u30f3\u304c\u6563\u898b\u3055\u308c\u307e\u3059\u306d\u3002<\/p>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>@echo off\nsetlocal\nset OSGEO4W_ROOT=C:\\OSGeo4W\nset PATH=%OSGEO4_ROOTW%\\bin;%PATH%\ncall %OSGEO4W_ROOT%\\etc\\ini\\gdal.bat\n\nif exist *.sqlite del *.sqlite\n\nset SQL=SELECT\nset SQL=%SQL% ST_Union(ST_buffer(geometry, 0.0001)) AS geometry,\nset SQL=%SQL% SUBSTR(JCODE, 1, 2) AS pref_code,\nset SQL=%SQL% KEN AS pref_name\nset SQL=%SQL% FROM japan_ver84\nset SQL=%SQL% WHERE pref_code BETWEEN &#39;36&#39; AND &#39;39&#39;\nset SQL=%SQL% GROUP BY pref_code\n\nogr2ogr ^\n    -nln     prefs ^\n    -dialect sqlite ^\n    -sql     &quot;%SQL%&quot; ^\n    shikoku.sqlite \/vsizip\/japan_ver84.zip\n\nset SQL=SELECT\nset SQL=%SQL% geometry,\nset SQL=%SQL% SUBSTR(address, 1, 3) AS city_name\nset SQL=%SQL% FROM office_latlon_pref_utf8_20180611\nset SQL=%SQL% WHERE pref_cd BETWEEN &#39;36&#39; AND &#39;39&#39;\n\nogr2ogr ^\n    -nln     capitals ^\n    -s_srs   EPSG:4326 ^\n    -t_srs   EPSG:6668 ^\n    -oo      X_POSSIBLE_NAMES=lon ^\n    -oo      Y_POSSIBLE_NAMES=lat ^\n    -dialect sqlite ^\n    -sql     &quot;%SQL%&quot; ^\n    -update ^\n    shikoku.sqlite office_latlon_pref_utf8_20180611.csv<\/code><\/pre><\/div>\n\n\n\n<p>\u3000ogr2ogr \u304c 2 \u56de\u4f7f\u7528\u3055\u308c\u3066\u3044\u307e\u3059\u304c\u30011 \u56de\u76ee\u306f\u770c\u5883\u306e\u30c7\u30fc\u30bf\uff08prefs\uff09\u3092\u30012 \u56de\u76ee\u306f\u770c\u5e81\u6240\u5728\u5730\u306e\u30c7\u30fc\u30bf\uff08capitals\uff09\u3092\u4f5c\u6210\u3057\u307e\u3059\u3002\u305d\u3057\u3066\u4e21\u65b9\u306e\u30c7\u30fc\u30bf\u3068\u3082 shikoku.sqlite \u3068\u3044\u3046\u30d5\u30a1\u30a4\u30eb\u306b\u51fa\u529b\u3057\u3066\u3044\u307e\u3059\u3002<br><\/p>\n\n\n\n<h3 class=\"wp-block-heading\">\u770c\u5883\u30c7\u30fc\u30bf\u306e\u4f5c\u6210<\/h3>\n\n\n\n<p>\u300020 \u884c\u76ee\u306e -sql \u306e\u5f15\u6570\u3067\u4e0e\u3048\u3089\u308c\u308b SQL \u5909\u6570\u306f\u6b21\u306e\u3088\u3046\u306b\u306a\u308a\u307e\u3059\uff08\u5b9f\u969b\u306f\u30a4\u30f3\u30c7\u30f3\u30c8\u3001\u6539\u884c\u306a\u3057\uff09\u3002<\/p>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-sql\" data-lang=\"SQL\"><code>SELECT\n    ST_Union(ST_buffer(geometry, 0.0001)) AS geometry,\n    SUBSTR(JCODE, 1, 2) AS pref_code,\n    KEN AS pref_name\nFROM japan_ver84\nWHERE pref_code BETWEEN &#39;36&#39; AND &#39;39&#39;\nGROUP BY pref_code<\/code><\/pre><\/div>\n\n\n\n<p>\u3000\u524d\u56de\u306e\u554f\u984c\u3067\u306f ogr2ogr \u306e -clipsrc \u3067\u5143\u30c7\u30fc\u30bf\u304b\u3089\u5fc5\u8981\u306a\u30c7\u30fc\u30bf\u3092\u62bd\u51fa\u3057\u307e\u3057\u305f\u304c\u3001\u4eca\u56de\u306f\u300c\u56db\u56fd 4 \u770c\u300d\u306a\u306e\u3067\u90fd\u9053\u5e9c\u770c\u30b3\u30fc\u30c9\uff08pref_code\uff09\u3067\u62bd\u51fa\u6761\u4ef6\u3092\u4e0e\u3048\u3066\u3044\u307e\u3059\u3002\u90fd\u9053\u5e9c\u770c\u30b3\u30fc\u30c9\u306f\u5143\u30c7\u30fc\u30bf\u306b\u542b\u307e\u308c\u3066\u3044\u308b\u5e02\u753a\u6751\u30b3\u30fc\u30c9\uff08JCODE\uff09\u306e\u5148\u982d\u306e 2 \u6587\u5b57\u306a\u306e\u3067\u3001SQLite \u306e SUBSTR \u95a2\u6570\u3067\u3053\u308c\u3092\u53d6\u5f97\u3057\u3066\u3044\u307e\u3059\u3002<br>\u3000\u307e\u305f\u3001\u524d\u56de\u306f\u65e7\u4e3b\u56fd\u306e\u30c7\u30fc\u30bf\u3092\u73fe\u5728\u306e\u69cb\u6210\u56fd\u540d\u306e\u5217\u6319\uff08WHERE NAME IN (\u2026)\uff09\u3057\u3066\u5408\u4f75\u51e6\u7406\u3092\u884c\u3044\u307e\u3057\u305f\u304c\u3001\u4eca\u56de\u306f pref_code \u3067\u30b0\u30eb\u30fc\u30d4\u30f3\u30b0\uff08GROUP BY pref_code\uff09\u3057\u3066\u3053\u308c\u3092\u884c\u3063\u3066\u3044\u307e\u3059\u3002<br><\/p>\n\n\n\n<h3 class=\"wp-block-heading\">\u770c\u5e81\u6240\u5728\u5730\u30c7\u30fc\u30bf\u306e\u4f5c\u6210<\/h3>\n\n\n\n<p>\u300029 \u884c\u76ee\u4ee5\u4e0b\u306f ogr2ogr \u3067 csv \u5f62\u5f0f\u306e\u30c6\u30ad\u30b9\u30c8\u30d5\u30a1\u30a4\u30eb\u304b\u3089\u30c7\u30fc\u30bf\u3092\u4f5c\u6210\u3059\u308b\u6642\u306e\u5b9a\u77f3\u3067\u3059\u3002\u3059\u306a\u308f\u3061<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u5165\u529b\u30c7\u30fc\u30bf\uff08source\uff09\u306e\u5ea7\u6a19\u53c2\u7167\u7cfb\u3092 -s_srs \u306e\u5f15\u6570\u3067\u3001\u51fa\u529b\u30c7\u30fc\u30bf\uff08target\uff09\u306e\u5f15\u6570\u3067\u4e0e\u3048\u308b\u3002\u5f15\u6570\u306b\u306f <a href=\"https:\/\/lemulus.me\/column\/epsg-list-gis#google_vignette\">EPSG \u30b3\u30fc\u30c9<\/a>\u3092\u7528\u3044\u308b<\/li>\n\n\n\n<li>-oo \u30aa\u30d7\u30b7\u30e7\u30f3\u306e\u5f15\u6570 X_POSSIBLE_NAMES\u3001Y_POSSIBLE_NAMES \u306b\u5bfe\u5fdc\u3059\u308b csv \u306e\u30ab\u30e9\u30e0\u540d\u3092\u6307\u5b9a\u3059\u308b<\/li>\n\n\n\n<li>\u65e2\u5b58\u306e\u30d5\u30a1\u30a4\u30eb\u306b\u8ffd\u52a0\u3059\u308b\u5834\u5408\u306f -update \u3092\u52a0\u3048\u308b<\/li>\n<\/ul>\n\n\n\n<p>\u300036 \u884c\u76ee\u306e SQL \u5909\u6570\u306f\u4ee5\u4e0b\u306e\u901a\u308a\u3067\u3001\u56db\u56fd 4 \u770c\u306e\u770c\u5e81\u6240\u5728\u5730\u306e\u5e02\u540d\uff08city_name\uff09\u306f\u30d5\u30eb\u306e\u6240\u5728\u5730\uff08address\uff09\u306e\u4e0a 3 \u6587\u5b57\u3067\u5f97\u3089\u308c\u308b\u306e\u3067\u3053\u3046\u3057\u3066\u3044\u307e\u3059\u3002\u300c\u540d\u53e4\u5c4b\u5e02\u300d\u3068\u304b\u306e\u5834\u5408\u306f\u8981\u5909\u66f4\u306b\u306a\u308a\u307e\u3059\uff08\u30d2\u30f3\u30c8 CASE \u2026 END\uff09\u3002<\/p>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-sql\" data-lang=\"SQL\"><code>SELECT\n    geometry,\n    SUBSTR(address, 1, 3) AS city_name\nFROM office_latlon_pref_utf8_20180611\nWHERE pref_cd BETWEEN &#39;36&#39; AND &#39;39&#39;<\/code><\/pre><\/div>\n\n\n\n<div style=\"height:24px\" aria-hidden=\"true\" class=\"wp-block-spacer\"><\/div>\n\n\n\n<h3 class=\"wp-block-heading\">\u307e\u3068\u3081<\/h3>\n\n\n\n<p>\u3000\u4ee5\u4e0a\u3001\u524d\u56de\u6307\u6458\u3057\u305f\u300c\u30d0\u30c3\u30c1\u30d5\u30a1\u30a4\u30eb\u306e\u518d\u5229\u7528\u300d\u306e\u5b9f\u4f8b\u306b\u306a\u308a\u307e\u3059\u3002\u5b66\u3076\u307b\u3069\u306b\u4ed5\u4e8b\u304c\u697d\u306b\u306a\u308b\u30cf\u30ba\u3067\u3059\u3002\u7279\u306b SQL \u306f\u4ed6\u306e\u7528\u9014\u306b\u3082\u6d3b\u7528\u3067\u304d\u3066\u8d85\u5f37\u529b\u3067\u3059\u3002<br><br>\u3000\u3068\u3053\u308d\u3067\u7686\u3055\u3093\u306f\u300c\u30d9\u30af\u30bf\u30fc\u30c7\u30fc\u30bf \uff1d \u30b7\u30a7\u30fc\u30d7\u30d5\u30a1\u30a4\u30eb\u300d\u3068\u8a8d\u8b58\u3057\u3066\u3044\u307e\u305b\u3093\u304b\uff1f\u3000\u3082\u3046 1 \u70b9\u3001\u4eca\u56de\u4e3b\u5f35\u3057\u305f\u3044\u306e\u306f\u300c<strong>\u8131\u30fb\u30b7\u30a7\u30fc\u30d7\u30d5\u30a1\u30a4\u30eb<\/strong>\u300d\u3067\u3059\u3002<br>\u3000\u3054\u627f\u77e5\u306e\u3088\u3046\u306b\u3001\u30b7\u30a7\u30fc\u30d7\u30d5\u30a1\u30a4\u30eb\u306f\u4e00\u3064\u306e\u30ec\u30a4\u30e4\u30fc\u3092\u8868\u73fe\u3059\u308b\u306e\u306b\u6700\u4f4e\u3067\u3082 3 \u3064\u306e\u30d5\u30a1\u30a4\u30eb\uff08.shp\u3001.shx\u3001.dbf\uff09\u3092\u5fc5\u8981\u3068\u3057\u307e\u3059\uff08\u5b9f\u8cea\u7684\u306b\u306f .prj \u3082\u5fc5\u9808\uff09\u3002\u3053\u306e\u5185\u3001\u5c5e\u6027\u3092\u53ce\u7d0d\u3059\u308b .dbf \u306f dBASE \u3068\u3044\u3046\u4eca\u3084\u6b86\u3069\u4f7f\u308f\u308c\u3066\u3044\u306a\u3044\u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u7ba1\u7406\u30b7\u30b9\u30c6\u30e0\uff08DBMS\uff09\u306e\u30d5\u30a1\u30a4\u30eb\u5f62\u5f0f\u3067\u3059\u3002\u305d\u306e\u4ed6\u306e\u524d\u6642\u4ee3\u7684\u306a\u5236\u7d04\u3082\u3042\u308a\u3001QGIS \u306f\u7b2c 3 \u7248\u304b\u3089 Geopackage \u3092\u65e2\u5b9a\u306e\u30c7\u30fc\u30bf\u5f62\u5f0f\u306b\u5909\u3048\u3066\u3044\u307e\u3059\u3002<br>\u3000Geopackage \u306f SQLite \u306b\u5bfe\u3057\u3066\u30e9\u30b9\u30bf\u30fc\u30c7\u30fc\u30bf\u3082\u6271\u3048\u308b\u3088\u3046\u306b\u3057\u305f\u62e1\u5f35\u5f62\u5f0f\u3067\u3059\u3002\u305d\u3057\u3066 <strong>SQLite \u306f Android \u3067\u3082\u4f7f\u308f\u308c\u3066\u3044\u308b\u666e\u901a\u306e DBMS \u3067\u3059<\/strong>\u3002<br>\u3000\u4eca\u56de\u306e\u4f8b\u3060\u3068 shikoku.sqlite \u306f\u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u3067\u3001prefs \u304a\u3088\u3073 capitals \u306f shikoku.sqlite \u5185\u306e\u30c6\u30fc\u30d6\u30eb\uff08GIS \u306e\u7528\u8a9e\u3067\u306f\u300c\u30ec\u30a4\u30e4\u30fc\u300d\uff09\u3067\u3059\u3002\u305d\u3057\u3066 SQLite \u306b\u3042\u3063\u3066\u306f\u5e7e\u4f55\u60c5\u5831\uff08geometry\uff09\u306f\u30c6\u30fc\u30d6\u30eb\u5185\u306e 1 \u3064\u306e\u5c5e\u6027\u306b\u4ed6\u306a\u308a\u307e\u305b\u3093\u3002\u30b7\u30a7\u30fc\u30d7\u30d5\u30a1\u30a4\u30eb\u3088\u308a\u968f\u5206\u30b9\u30c3\u30ad\u30ea\u3057\u305f\u3068\u601d\u3044\u307e\u305b\u3093\u304b\u3002<br><br>\u3000\u7686\u304c\u6163\u7fd2\u306b\u56da\u308f\u308c\u305a\u666e\u901a\u306e\u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u3092\u4f7f\u3046\u3088\u3046\u306b\u306a\u308c\u3070\u300c\u8131\u30fb\u30b7\u30a7\u30fc\u30d7\u30d5\u30a1\u30a4\u30eb\u300d\u304c\u9032\u3080\u3068\u601d\u3046\u306e\u3067\u3059\u304c\u5982\u4f55\u3067\u3057\u3087\u3046\u3002<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u3000\u524d\u56de\u306b\u5f15\u304d\u7d9a\u304d\u3001ogr2ogr \u306e\u7d39\u4ecb\u3067\u3059\u3002\u3000\u4eca\u56de\u306f\u4e0b\u306b\u793a\u3059\u56db\u56fd 4 \u770c\u306e\u770c\u5e81\u6240\u5728\u5730\u306e\u5730\u56f3\u3092\u4f5c\u6210\u3057\u307e\u3059\u3002 \u3000\u4eca\u56de\u4f7f\u7528\u3057\u305f\u5143\u30c7\u30fc\u30bf\u306f\u6b21\u306e 2 \u70b9\u3067\u3059\u3002 \u3000\u3044\u304d\u306a\u308a\u3067\u3059\u304c\u3001\u3053\u308c\u3089\u306e\u30c7\u30fc\u30bf\u304b\u3089\u4e3b\u984c\u56f3\u3092\u4f5c\u308b\u305f\u3081\u306e\u30d0\u30c3\u30c1\u30d5\u30a1\u30a4\u30eb [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"closed","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[7],"tags":[18,22,17,24,23],"class_list":["post-231","post","type-post","status-publish","format-standard","hentry","category-it","tag-cui","tag-gis","tag-ogr2ogr","tag-sql","tag-sqlite"],"_links":{"self":[{"href":"https:\/\/www.flumen-jp.com\/wordpress\/index.php\/wp-json\/wp\/v2\/posts\/231","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.flumen-jp.com\/wordpress\/index.php\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.flumen-jp.com\/wordpress\/index.php\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.flumen-jp.com\/wordpress\/index.php\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/www.flumen-jp.com\/wordpress\/index.php\/wp-json\/wp\/v2\/comments?post=231"}],"version-history":[{"count":12,"href":"https:\/\/www.flumen-jp.com\/wordpress\/index.php\/wp-json\/wp\/v2\/posts\/231\/revisions"}],"predecessor-version":[{"id":619,"href":"https:\/\/www.flumen-jp.com\/wordpress\/index.php\/wp-json\/wp\/v2\/posts\/231\/revisions\/619"}],"wp:attachment":[{"href":"https:\/\/www.flumen-jp.com\/wordpress\/index.php\/wp-json\/wp\/v2\/media?parent=231"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.flumen-jp.com\/wordpress\/index.php\/wp-json\/wp\/v2\/categories?post=231"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.flumen-jp.com\/wordpress\/index.php\/wp-json\/wp\/v2\/tags?post=231"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}