-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathjpDataMesh.py
112 lines (87 loc) · 5.09 KB
/
jpDataMesh.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
# -*- coding: utf-8 -*-
import os, posixpath, csv
from . import jpDataUtils
def getMesh1ByPrefName(name_pref):
str_code_pref = jpDataUtils.getPrefCodeByName(name_pref)
mesh1s = getMesh1ByPrefCode(str_code_pref)
unique_mesh1s = []
for x in mesh1s:
if x["code_mesh1"] not in unique_mesh1s:
unique_mesh1s.append(x["code_mesh1"])
return unique_mesh1s
def getMesh1ByPrefMuniName(name_pref, name_munis):
str_code_pref = jpDataUtils.getPrefCodeByName(name_pref)
int_code_pref = int(str_code_pref)
tempMesh1 = []
filePath = posixpath.join(os.path.dirname(__file__), "csv", "muni_mesh1.csv")
with open(filePath, "r") as f:
csvreader = csv.DictReader(f)
rows = list(csvreader)
for row in rows:
for name_muni in name_munis:
if int(row["code_pref"]) == int_code_pref and row["name_muni"] == name_muni:
if row["code_mesh1"] not in tempMesh1:
tempMesh1.append(row["code_mesh1"])
return tempMesh1
def getMesh1ByPrefCode(code_pref):
if code_pref == "":
return ""
int_code_pref = int(code_pref)
tempMesh1 = []
filePath = posixpath.join(os.path.dirname(__file__), "csv", "muni_mesh1.csv")
with open(filePath, "r") as f:
csvreader = csv.DictReader(f)
rows = list(csvreader)
for row in rows:
if int(row["code_pref"]) == int_code_pref:
tempMesh1.append(row)
return tempMesh1
def getMesh1ByPrefMuniCode(code_pref, code_muni):
int_code_pref = int(code_pref)
int_code_muni = int(code_muni)
tempMesh1 = []
filePath = posixpath.join(os.path.dirname(__file__), "csv", "muni_mesh1.csv")
with open(filePath, "r") as f:
csvreader = csv.DictReader(f)
rows = list(csvreader)
for row in rows:
if (
int(row["code_pref"]) == int_code_pref
and int(row["code_muni"]) == int_code_muni
):
tempMesh1.append(row)
return tempMesh1
def getMesh3ByPrefMuniCode(code_pref, code_muni):
int_code_pref = int(code_pref)
int_code_muni = int(code_muni)
tempMesh3 = []
filePath = posixpath.join(os.path.dirname(__file__), "csv", "muni_mesh3.csv")
with open(filePath, "r") as f:
csvreader = csv.DictReader(f)
rows = list(csvreader)
for row in rows:
if (
int(row["code_pref"]) == int_code_pref
and int(row["code_muni"]) == int_code_muni
):
tempMesh3.append(row)
return tempMesh3
def getMeshExpression(code_map):
str_expression = ""
if code_map == "L03-a":
str_expression = "CASE "
str_expression += 'WHEN "田" > "他農用地" AND "田" > "森林" AND "田" > "荒地" AND "田" > "建物用地" AND "田" > "道路" AND "田" > "鉄道" AND "田" > "他用地" AND "田" > "河川湖沼" AND "田" > "海水域" AND "田" > "ゴルフ場" AND "田" > "範囲外" THEN \'田\' '
str_expression += 'WHEN "他農用地" > "森林" AND "他農用地" > "荒地" AND "他農用地" > "建物用地" AND "他農用地" > "道路" AND "他農用地" > "鉄道" AND "他農用地" > "他用地" AND "他農用地" > "河川湖沼" AND "他農用地" > "海水域" AND "他農用地" > "ゴルフ場" AND "他農用地" > "範囲外" THEN \'他農用地\' '
str_expression += 'WHEN "森林" > "荒地" AND "森林" > "建物用地" AND "森林" > "道路" AND "森林" > "鉄道" AND "森林" > "他用地" AND "森林" > "河川湖沼" AND "森林" > "海水域" AND "森林" > "ゴルフ場" AND "森林" > "範囲外" THEN \'森林\' '
str_expression += 'WHEN "荒地" > "建物用地" AND "荒地" > "道路" AND "荒地" > "鉄道" AND "荒地" > "他用地" AND "荒地" > "河川湖沼" AND "荒地" > "海水域" AND "荒地" > "ゴルフ場" AND "荒地" > "範囲外" THEN \'荒地\' '
str_expression += 'WHEN "建物用地" > "道路" AND "建物用地" > "鉄道" AND "建物用地" > "他用地" AND "建物用地" > "河川湖沼" AND "建物用地" > "海水域" AND "建物用地" > "ゴルフ場" AND "建物用地" > "範囲外" THEN \'建物用地\' '
str_expression += 'WHEN "道路" > "鉄道" AND "道路" > "他用地" AND "道路" > "河川湖沼" AND "道路" > "海水域" AND "道路" > "ゴルフ場" AND "道路" > "範囲外" THEN \'道路\' '
str_expression += 'WHEN "鉄道" > "他用地" AND "鉄道" > "河川湖沼" AND "鉄道" > "海水域" AND "鉄道" > "ゴルフ場" AND "鉄道" > "範囲外" THEN \'鉄道\' '
str_expression += 'WHEN "他用地" > "河川湖沼" AND "他用地" > "海水域" AND "他用地" > "ゴルフ場" AND "他用地" > "範囲外" THEN \'他用地\' '
str_expression += 'WHEN "河川湖沼" > "海水域" AND "河川湖沼" > "ゴルフ場" AND "河川湖沼" > "範囲外" THEN \'河川湖沼\' '
str_expression += (
'WHEN "海水域" > "ゴルフ場" AND "海水域" > "範囲外" THEN \'海水域\' '
)
str_expression += 'WHEN "ゴルフ場" > "範囲外" THEN \'ゴルフ場\' '
str_expression += "ELSE '範囲外' END"
return str_expression