-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdest_prov.ado
276 lines (226 loc) · 10.3 KB
/
dest_prov.ado
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
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
capture program drop dest_prov
program define dest_prov
version 13
**! version 2.2
** aggiunto supporto per Codice NUTS3 2021
**! version 2.1
** aggiunta la provincia Sud Sardegna (SU)
**! version 2.0
** aggiunte le opzioni per creare le variabili
** codice regione istat (gregio)
** codice nuts3 (gnuts3)
** codice nuts2 (gnuts2)
** codice nuts1 (gnuts1)
**! version 1.1.0 06nov2014
** -aggiunta opzione tl(full|sigla) per fare il label con nome intero (default) o con la sigla della provincia
** -aggiunta opzione ignore
** -aggiunto supporto per Codice NUTS3 2010
**! version 1.0.0 02oct2014
** -converte anche le sigle delle provincie
** -tutte le variabili usate nel comando sono di tipo tempvar
** -introduzione di contract _CLONE e successivo merge
** -di fatto parallel non serve più (eliminata la relativa opzione)
** -eliminazione di codebook, problems che per dataset molto numerosi poteva allungare i tempi di esecuzione
** -il label della variabile con i codici delle provincie corrisponde al nome della variabile stessa
**! version 0.0.1 TomaHawk 28aug2014
syntax varlist (max=1) [if] [in] [, onlylab GENerate(name) tl(str) ignore ///
gregio(name) macro3(name) macro5(name) gnuts3(name) gnuts2(name) gnuts1(name) nuts(integer 2010)]
marksample touse, strok
tempvar dups clone ID _CLONE _NV
tempfile TMPF
if "`onlylab'"!="" confirm numeric variable `varlist'
else confirm string variable `varlist'
if `nuts'!=2010 & `nuts'!=2021 {
di in red "La revisione NUTS deve essere 2010 o 2021"
exit _rc
}
tempvar tmpvarlist
if "`generate'" == "" & "`onlylab'"=="" local nv "cod_prov"
else if "`generate'" != "" & "`onlylab'"=="" local nv "`generate'"
else if "`onlylab'"!="" local nv "`tmpvarlist'"
capture confirm variable `nv', exact
if !_rc {
di "variable `nv' already exists"
exit _rc
}
capture label drop `nv'
if "`tl'" == "" local tl "full"
assert "`tl'" == "full" | "`tl'" == "sigla" | "`tl'" == "nuts3"
qui clonevar `_CLONE' = `varlist'
if "`onlylab'"=="" {
qui replace `_CLONE' = trim(`_CLONE')
qui replace `_CLONE' = lower(`_CLONE')
}
gen `ID' = _n
preserve
contract `_CLONE'
drop _freq
if "`onlylab'"=="" {
qui gen int `_NV' = .
qui include "`c(sysdir_plus)'d/dest_prov.do"
qui clonevar `nv' = `_NV'
drop `_NV'
}
else qui clonevar `nv' = `_CLONE'
if "`gregio'" != "" | "`macro3'" != "" | "`macro5'" != "" | "`gnuts3'" != "" | "`gnuts2'" != "" | "`gnuts1'" != "" {
tempvar tmpregio
qui recode `nv' (1 2 3 4 5 6 96 103 = 1 "Piemonte") ///
(7 = 2 "Valle d'Aosta") ///
(8 9 10 11 = 7 "Liguria") ///
(12 13 14 15 16 17 18 19 20 97 98 108 = 3 "Lombardia") ///
(21 22 = 4 "Trentino-Alto Adige") ///
(23 24 25 26 27 28 29 = 5 "Veneto") ///
(30 31 32 93 = 6 "Friuli-Venezia Giulia") ///
(33 34 35 36 37 38 39 40 99 = 8 "Emilia-Romagna") ///
(41 42 43 44 109 = 11 "Marche") ///
(45 46 47 48 49 50 51 52 53 100 = 9 "Toscana") ///
(54 55 = 10 "Umbria") ///
(56 57 58 59 60 = 12 "Lazio") ///
(61 62 63 64 65 = 15 "Campania") ///
(66 67 68 69 = 13 "Abruzzo") ///
(70 94 = 14 "Molise") ///
(71 72 73 74 75 110 = 16 "Puglia") ///
(76 77 = 17 "Basilicata") ///
(78 79 80 101 102 = 18 "Calabria") ///
(81 82 83 84 85 86 87 88 89 = 19 "Sicilia") ///
(90 91 92 95 104 105 106 107 111 = 20 "Sardegna") ///
(*=.), gen(`tmpregio') label(`gregio')
if "`gregio'" != "" {
clonevar `gregio' = `tmpregio'
qui assert `nv'==. if `gregio'==.
label var `gregio' "Regione"
}
if "`macro3'" != "" {
qui recode `tmpregio' (1/8=1 "Nord") (9/12=2 "Centro") (13/20=3 "Sud e Isole"), gen(`macro3') label(`macro3')
qui assert `nv'==. if `macro3'==.
label var `macro3' "Macro Regioni"
}
if "`macro5'" != "" {
qui recode `tmpregio' (1 2 3 7=1 "Nord-Ovest") (4 5 6 8=2 "Nord-Est") (9/12=3 "Centro") (13/18=4 "Sud") (19 20=5 "Isole"), gen(`macro5') label(`macro5')
qui assert `nv'==. if `macro5'==.
label var `macro5' "Macro Regioni"
}
if "`gnuts3'" != "" {
tempname labnuts3
tempvar gnuts3num
clonevar `gnuts3num' = `nv'
if `nuts'==2010 label define `labnuts3' 1 "ITC11" 2 "ITC12" 3 "ITC15" 4 "ITC16" 5 "ITC17" 6 "ITC18" 96 "ITC13" 103 "ITC14" ///
7 "ITC20" ///
8 "ITC31" 9 "ITC32" 10 "ITC33" 11 "ITC34" ///
12 "ITC41" 13 "ITC42" 14 "ITC44" 15 "ITC4C" 16 "ITC46" 17 "ITC47" 18 "ITC48" 19 "ITC4A" 20 "ITC4B" 97 "ITC43" 98 "ITC49" 108 "ITC4D" ///
21 "ITH10" 22 "ITH20" ///
23 "ITH31" 24 "ITH32" 25 "ITH33" 26 "ITH34" 27 "ITH35" 28 "ITH36" 29 "ITH37" ///
30 "ITH42" 31 "ITH43" 32 "ITH44" 93 "ITH41" ///
33 "ITH51" 34 "ITH52" 35 "ITH53" 36 "ITH54" 37 "ITH55" 38 "ITH56" 39 "ITH57" 40 "ITH58" 99 "ITH59" ///
41 "ITI31" 42 "ITI32" 43 "ITI33" 44 "ITI34" 109 "ITI35" ///
45 "ITI11" 46 "ITI12" 47 "ITI13" 48 "ITI14" 49 "ITI16" 50 "ITI17" 51 "ITI18" 52 "ITI19" 53 "ITI1A" 100 "ITI15" ///
54 "ITI21" 55 "ITI22" ///
56 "ITI41" 57 "ITI42" 58 "ITI43" 59 "ITI44" 60 "ITI45" ///
61 "ITF31" 62 "ITF32" 63 "ITF33" 64 "ITF34" 65 "ITF35" ///
66 "ITF11" 67 "ITF12" 68 "ITF13" 69 "ITF14" ///
70 "ITF22" 94 "ITF21" ///
71 "ITF46" 72 "ITF47" 73 "ITF43" 74 "ITF44" 75 "ITF45" 110 "ITF48" ///
76 "ITF51" 77 "ITF52" ///
78 "ITF61" 79 "ITF63" 80 "ITF65" 101 "ITF62" 102 "ITF64" ///
81 "ITG11" 82 "ITG12" 83 "ITG13" 84 "ITG14" 85 "ITG15" 86 "ITG16" 87 "ITG17" 88 "ITG18" 89 "ITG19" ///
90 "ITG25" 91 "ITG26" 92 "ITG27" 95 "ITG28" 104 "ITG29" 105 "ITG2A" 106 "ITG2B" 107 "ITG2C"
if `nuts'==2021 label define `labnuts3' 1 "ITC11" 2 "ITC12" 3 "ITC15" 4 "ITC16" 5 "ITC17" 6 "ITC18" 96 "ITC13" 103 "ITC14" ///
7 "ITC20" ///
8 "ITC31" 9 "ITC32" 10 "ITC33" 11 "ITC34" ///
12 "ITC41" 13 "ITC42" 14 "ITC44" 15 "ITC4C" 16 "ITC46" 17 "ITC47" 18 "ITC48" 19 "ITC4A" 20 "ITC4B" 97 "ITC43" 98 "ITC49" 108 "ITC4D" ///
21 "ITH10" 22 "ITH20" ///
23 "ITH31" 24 "ITH32" 25 "ITH33" 26 "ITH34" 27 "ITH35" 28 "ITH36" 29 "ITH37" ///
30 "ITH42" 31 "ITH43" 32 "ITH44" 93 "ITH41" ///
33 "ITH51" 34 "ITH52" 35 "ITH53" 36 "ITH54" 37 "ITH55" 38 "ITH56" 39 "ITH57" 40 "ITH58" 99 "ITH59" ///
41 "ITI31" 42 "ITI32" 43 "ITI33" 44 "ITI34" 109 "ITI35" ///
45 "ITI11" 46 "ITI12" 47 "ITI13" 48 "ITI14" 49 "ITI16" 50 "ITI17" 51 "ITI18" 52 "ITI19" 53 "ITI1A" 100 "ITI15" ///
54 "ITI21" 55 "ITI22" ///
56 "ITI41" 57 "ITI42" 58 "ITI43" 59 "ITI44" 60 "ITI45" ///
61 "ITF31" 62 "ITF32" 63 "ITF33" 64 "ITF34" 65 "ITF35" ///
66 "ITF11" 67 "ITF12" 68 "ITF13" 69 "ITF14" ///
70 "ITF22" 94 "ITF21" ///
71 "ITF46" 72 "ITF47" 73 "ITF43" 74 "ITF44" 75 "ITF45" 110 "ITF48" ///
76 "ITF51" 77 "ITF52" ///
78 "ITF61" 79 "ITF63" 80 "ITF65" 101 "ITF62" 102 "ITF64" ///
81 "ITG11" 82 "ITG12" 83 "ITG13" 84 "ITG14" 85 "ITG15" 86 "ITG16" 87 "ITG17" 88 "ITG18" 89 "ITG19" ///
90 "ITG25" 91 "ITG26" 92 "ITG27" 95 "ITG28" 111 "ITG2H"
label values `gnuts3num' `labnuts3'
decode `gnuts3num', gen(`gnuts3')
label var `gnuts3' "NUTS3 `nuts'"
qui count if `gnuts3'==""
local m1=r(N)
qui count if `nv'==.
local m2=r(N)
if `m1'!=`m2' {
di in red "Alcune provincie sono prive di calssificazione NUTS3"
fre `nv' if `gnuts3'=="" & `nv'!=.
}
drop `gnuts3num'
}
if "`gnuts2'" != "" {
tempname labnuts2
tempvar gnuts2num
clonevar `gnuts2num' = `tmpregio'
qui replace `gnuts2num'=41 if `nv' == 21
qui replace `gnuts2num'=42 if `nv' == 22
label define `labnuts2' 1 "ITC1" 2 "ITC2" 3 "ITC4" 41 "ITH1" 42 "ITH2" 5 "ITH3" 6 "ITH4" 7 "ITC3" 8 "ITH5" ///
9 "ITI1" 10 "ITI2" 11 "ITI3" 12 "ITI4" 13 "ITF1" 14 "ITF2" 15 "ITF3" 16 "ITF4" 17 "ITF5" 18 "ITF6" ///
19 "ITG1" 20 "ITG2"
label values `gnuts2num' `labnuts2'
decode `gnuts2num', gen(`gnuts2')
label var `gnuts2' "NUTS2 `nuts'"
drop `gnuts2num'
}
if "`gnuts1'" != "" {
tempvar gnuts1num
qui recode `tmpregio' (1 2 3 7 = 1 "ITC" ) (4 5 6 8 = 2 "ITH") (9 10 11 12 = 3 "ITI") (13 14 15 16 17 18 = 4 "ITF") (19 20 = 5 "ITG"), gen(`gnuts1num') label(`gnuts1')
decode `gnuts1num', gen(`gnuts1')
label var `gnuts1' "NUTS1 `nuts'"
drop `gnuts1num'
}
}
qui save `TMPF', replace
restore
qui merge m:1 `_CLONE' using `TMPF', assert(1 3) keepusing(`nv' `gregio' `macro3' `macro5' `gnuts3' `gnuts2' `gnuts1') nogenerate
sort `ID'
drop `ID'
qui include "`c(sysdir_plus)'d/dest_prov_lab.do"
label values `nv' `nv'
order `nv', after(`varlist')
if "`gregio'"!="" label values `gregio' `gregio'
if "`macro3'"!="" label values `macro3' `macro3'
if "`macro5'"!="" label values `macro5' `macro5'
/*** CHECKS ***/
local ERROR = 0
**set trace on
qui levelsof `nv', local(test)
foreach k of local test {
**set trace on
if "`:label (`nv') `k', strict'" == "" {
local ERROR = 1
di as error "Ci sono delle categorie di `nv' senza label. Questa è la lista:"
di _newline "Valore `k' senza label"
di "Associato a questi valori di `varlist'"
qui levelsof `varlist' if `nv'==`k', local(lista) clean
foreach i of local lista {
di "`i'" _newline
}
}
}
drop `_CLONE'
if `ERROR'==1 & "`ignore'" == "" {
di "Non sono stati passati tutti i check!"
di "correggere i valori nella variabile `varlist', quindi riprovare. Oppure specifica l'opzione ignore"
capture drop `nv'
exit
}
if "`onlylab'" != "" {
local labavar : variable label `varlist'
qui drop `varlist'
rename `nv' `varlist'
label var `varlist' "`labavar'"
label copy `nv' `varlist' , replace
label values `varlist' `varlist'
}
else label var `nv' "Codice ISTAT provincia"
end