全部版块 我的主页
论坛 计量经济学与统计论坛 五区 计量经济学与统计软件 Stata专版
1322 3
2015-01-26
如果我要计算河北省每个城市的平均受教育水平,需要如下命令:
mean edu if region>130099 & region<130101
mean edu if region>130199 & region<130201
mean edu if region>130299 & region<130301
……
需要至少重复11次,如果我使用如下语句:
forv region=130100(100)131100 {
mean edu
}
结果stata把全国的平均受教育水平重复算了11遍,说明上述语句有问题。有没有简单方法能一次性分别算出11个城市的平均受教育水平(最好用循环语句,其中石家庄市所有个体的region代码均为130100,唐山130200,秦皇岛130300,其他城市以此类推)?
二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

全部回复
2015-1-27 00:41:31
forvalues i=130100(100)131100 {
local j = `i'+100
summ edu if region>130100 & region<=`j'
}
Good luck
二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

2015-1-27 02:42:35
循环这个东西,该用的时候用,不该用的时候不用。循环本身的运行速度又不快,应该说没必要用的时候尽量避免,而不是最好选择循环。
看你的意思,是要按每个region对edu算均值,那直接用bys命令就好了。
bys region: egen mean_edu=mean(edu)
如果你不需要生成新变量,而仅仅是需要看一下均值,那用下面的命令也可以:
bys region: sum edu
二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

2015-1-27 11:24:11
感谢以上两位的回答!
二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

相关推荐
栏目导航
热门文章
推荐文章

说点什么

分享

扫码加好友,拉您进群
各岗位、行业、专业交流群