首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >在Stata中使用并行列表生成新变量

在Stata中使用并行列表生成新变量
EN

Stack Overflow用户
提问于 2020-09-19 05:49:34
回答 1查看 36关注 0票数 0

我正在尝试从Stata中的两个并行列表生成一组新的变量。我有一组列是每个人口统计组在劳动力中的百分比,另一组列是每个人口统计组在特定职业中的百分比。我想将后者除以前者,为每一组创建一个拥挤分数。

代码语言:javascript
运行
复制
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'
}

这段代码有一个语法错误,我还没找出来。我想知道有没有其他方法可以做到这一点?通过将一个变量列表除以另一个变量列表作为并行列表来生成新的变量?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-09-19 08:28:50

代码不正确。word # of不会取消变量列表的缩写。

单词的规则是单词之间用空格分隔,引号除外。异常在这里是不相关的。因此,每个通配符varlist恰好是一个单词。

代码语言:javascript
运行
复制
. display `: word count "pct_lf_tot_Male-pct_lf_tot_o_f_65_plus"'
1

如果没有你的数据,我们不能真正测试任何东西,但一个有把握的猜测是你需要更多的东西,比如

代码语言:javascript
运行
复制
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'
}
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/63963239

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档