создание новой переменной с использованием параллельных списков в Stata

#stata #stata-macros

#stata #stata-макросы

Вопрос:

Я пытаюсь сгенерировать новый набор переменных из двух параллельных списков в Stata. У меня есть набор столбцов, которые представляют собой процент каждой демографической группы в рабочей силе, и другой набор столбцов, которые представляют собой процент каждой демографической группы в определенной профессии. Я хочу разделить последнее на первое, чтобы создать общий балл для каждой группы.

 local pct_lf "pct_lf_tot_Male-pct_lf_tot_o_f_65_plus
* pct in labor force by demo group
local pct_occ "pct_Male-pct_o_f_65_plus" 
* pct in occupation by demo group
local n : word count `pct_occ'

forvalues i = 1/`n' {
     local a : word `i' of `pct_lf'
     local b : word `i' of `pct_occ' 
     gen crd_`b'=`b'/`a'
}
  

В этом коде есть синтаксическая ошибка, которую я не понял. Мне интересно, есть ли другой способ сделать это? Сгенерировать новую переменную, разделив список переменных на другой список переменных в порядке параллельных списков?

Комментарии:

1. В чем ошибка?

2. Ваш код выглядит правильно. Если бы мне пришлось делать дикие предположения, у вас, вероятно, разное количество элементов в ваших двух списках. Как правило, я бы избегал «-«-подстановочных знаков в ваших списках переменных. Это может привести к ошибке.

Ответ №1:

Код неверен. word # of не отменит сокращение varlists.

Правила для слов таковы, что слова разделяются пробелами, за исключением того, что кавычки связывают. Исключение здесь не имеет значения. Таким образом, каждый список переменных с подстановочными знаками состоит ровно из одного слова.

 . display `: word count "pct_lf_tot_Male-pct_lf_tot_o_f_65_plus"'
1
  

Мы ничего не можем проверить по-настоящему без ваших данных, но уверенное предположение заключается в том, что вам нужно что-то вроде

 unab pct_lf : pct_lf_tot_Male-pct_lf_tot_o_f_65_plus
* pct in labor force by demo group
unab pct_occ : pct_Male-pct_o_f_65_plus 
* pct in occupation by demo group

local n : word count `pct_occ'

forvalues i = 1/`n' {
     local a : word `i' of `pct_lf'
     local b : word `i' of `pct_occ' 
     gen crd_`b'=`b'/`a'
}