楼主: 木木草田
15932 8

[数据管理求助] 怎么把国有的设置为1,非国有的设置为0 [推广有奖]

  • 3关注
  • 1粉丝

大专生

70%

还不是VIP/贵宾

-

威望
0
论坛币
3 个
通用积分
0.0178
学术水平
6 点
热心指数
8 点
信用等级
5 点
经验
766 点
帖子
43
精华
0
在线时间
51 小时
注册时间
2013-11-12
最后登录
2021-9-7

楼主
木木草田 发表于 2014-12-6 23:50:10 |AI写论文

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

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

经管之家联合CDA

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

感谢您参与论坛问题回答

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

+2 论坛币
下载了上市公司实际控制人性质的数据,但是是显示的代码比如1000,1100,2100,3100等四位数代码,我想把其中的1000,1100,2000,2120等设置为1,其它代码设置为0,用stata什么命令能实现呢?
二维码

扫码加我 拉你入群

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

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

关键词:非国有 Stata 实际控制人 上市公司 tata 上市公司

沙发
iorent 发表于 2014-12-7 15:23:56
gen...replace命令可以,最后要注意定义缺失值
已有 1 人评分论坛币 学术水平 热心指数 收起 理由
SpencerMeng + 10 + 1 + 1 热心帮助其他会员

总评分: 论坛币 + 10  学术水平 + 1  热心指数 + 1   查看全部评分

藤椅
木木草田 发表于 2014-12-7 15:48:35
iorent 发表于 2014-12-7 15:23
gen...replace命令可以,最后要注意定义缺失值
好的,我试试,谢谢你啊~

板凳
Alfred_G 学生认证  发表于 2014-12-7 16:30:08
假设你这个变量叫做 enterprise,在不考虑缺失值的情况下,用这个命令
recode enterprise (1000=1) (1100=1)(2000=1)(2120=1) (else=0), gen (newenterprise)
这个比较快捷
已有 2 人评分经验 论坛币 学术水平 热心指数 收起 理由
admin_kefu + 50 热心帮助其他会员
SpencerMeng + 60 + 1 + 1 观点有启发

总评分: 经验 + 60  论坛币 + 50  学术水平 + 1  热心指数 + 1   查看全部评分

报纸
cg771298821 发表于 2015-8-28 22:07:13
楼主,我也遇到了这个问题,请问你是怎么解决的?   急求!

地板
ASIN96 学生认证  发表于 2020-6-7 14:11:27
Alfred_G 发表于 2014-12-7 16:30
假设你这个变量叫做 enterprise,在不考虑缺失值的情况下,用这个命令
recode enterprise (1000=1) (1100= ...
您好,谢谢您分享的命令!我在操作过程中发现所有性质的企业(包括国有企业)都被赋值为0了,请问这可以怎样修改呢?

7
moving11 发表于 2020-12-3 15:39:22
ASIN96 发表于 2020-6-7 14:11
您好,谢谢您分享的命令!我在操作过程中发现所有性质的企业(包括国有企业)都被赋值为0了,请问这可以怎 ...
你好,你解决了吗,我也是出现了一样的问题,求教怎么解决

8
moving11 发表于 2020-12-3 15:39:46
cg771298821 发表于 2015-8-28 22:07
楼主,我也遇到了这个问题,请问你是怎么解决的?   急求!
你解决了吗?求教

9
叁叁今天好好生活了嘛 发表于 2021-12-18 03:29:28
这是我根据老师给的方法做的,可以参考一下

labone,n(1) //批量添加标签

drop in 1/2 //删除第一第二行

rename stkcd id //重命名证券代码为id

gen year=substr(reptdt,1,4),a(id) //从统计截止日期中提取年份

gen month=real(substr(reptdt,6,2)),a(year) //从会计期间中提取月份

keep if month==12

keep if s0701a=="1" //根据年报公布得出实际控制人

keep id year s0702b //保留id year 实际控制人性质

****是否包含"1100、2000、2100、2120"

gen a1=strpos(s0702b,"1100") //如果s0702b中包含有1100,a1等于1100第一次出现的位置,否则a1为0

gen a2=strpos(s0702b,"2000") //如果s0702b中包含有2000,a2等于2000第一次出现的位置,否则a2为0

gen a3=strpos(s0702b,"2100") //如果s0702b中包含有2100,a3等于2100第一次出现的位置,否则a3为0

gen a4=strpos(s0702b,"2120") //如果s0702b中包含有2120,a4等于2120第一次出现的位置,否则a4为0

**如果s0702b中包含1100或2000或2100或2120,国有产权性质SOE=1, 否则为0

gen SOE=(a1>0) | (a2>0) | (a3>0) | (a4>0)

keep id year SOE //保留id year SOE

bys id year: egen a=total(SOE) //部分公司一年有多个值

drop SOE

gen SOE=0

replace SOE=1 if a>0 //如果有一个为国有,则为国有

keep id year SOE

duplicates drop //删除重复值

label var SOE "国有产权性质" //给SOE添加标签为国有产权性质

save 产权性质.dta,replace

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

本版微信群
加好友,备注jltj
拉您入交流群
GMT+8, 2025-12-22 17:20