楼主: Brook1114
1865 1

[Stata高级班] 如何生成新的id [推广有奖]

  • 0关注
  • 0粉丝

硕士生

98%

还不是VIP/贵宾

-

威望
0
论坛币
735 个
通用积分
0
学术水平
1 点
热心指数
0 点
信用等级
0 点
经验
1912 点
帖子
124
精华
0
在线时间
39 小时
注册时间
2009-2-4
最后登录
2020-9-8

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

求职就业群
赵安豆老师微信:zhaoandou666

经管之家联合CDA

送您一个全额奖学金名额~ !

感谢您参与论坛问题回答

经管之家送您两个论坛币!

+2 论坛币
大家好:
    数据如下:
城市                     个人                  家庭(需要生成)
110101                    1                     1
110101                    2                      1
110101                    3                      1
110101                     1                     2
110101                    2                       2
110101                    1                       3
110101                     2                        3
110101                      3                      3
110101                      4                        3
110101                       1                        4
110101                       2                       4
在个人的一栏中,1 2 3 ,1 2 , 1 2 3 4 属于 每个家庭,也就是每次遇到一个一,就是一个新的家庭。
我想把家庭成员都归为一个家庭内,即,第一个1 2 3 在id中都标记为1, 第二个1 2 标记为2 ,等等。生成“家庭”这个新变量。请问该如何生成”家庭“这个新变量?是否要用循环来实现(每次在“个人”中遇到1 就自动在“家庭”中加1)?

我试了egen newid=group(城市  个人),生成的还是和“个人”变量一样。



谢谢!
二维码

扫码加我 拉你入群

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

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

关键词:Group egen 新变量 wid 大家好 如何

沙发
arlionn 在职认证  发表于 2010-12-19 09:09:50 |只看作者 |坛友微信交流群
*-http://www.pinggu.org/bbs/thread-992234-1-1.html

  clear
  input city ind famly
  110101                    1                       1
  110101                    2                       1
  110101                    3                       1
  110101                    1                       2
  110101                    2                       2
  110101                    1                       3
  110101                    2                       3
  110101                    3                       3
  110101                    4                       3
  110101                    1                       4
  110101                    2                       4
  end

  drop famly

  qui tab city
  local N_city = r(r)
  qui sum ind
  local N_ind = r(N)
  gen family = .
  set trace on
  forvalues c = 1/`N_city'{
     local j = 0
     forvalues i = 1/`N_ind'{
           if ind[`i']==1{
             replace family = `++j' in `i'
           }
           else{
             replace family = `j' in `i'
           }            
         }
  }

使用道具

您需要登录后才可以回帖 登录 | 我要注册

本版微信群
加好友,备注jltj
拉您入交流群

京ICP备16021002-2号 京B2-20170662号 京公网安备 11010802022788号 论坛法律顾问:王进律师 知识产权保护声明   免责及隐私声明

GMT+8, 2024-5-2 17:58