分类变量
假设我们已经安装好了Stata,,下载network包。
将要处理的数据在Excel中整理成下图所示:
其中id代表研究,t代表治疗,r是反应数(本例中是每组因副作用脱落的数目),n是样本量;注意每一行代表一个研究的一个臂(组),如果一个研究有三臂,那么就占三行。分析时需将id以数字来依次编号Study。同样,依次以数字来编号t。特别注意的是,同一研究中从上到下,治疗的编码只能增大,不能降低。一般来说,将安慰剂编码为1。
- 点击Stata菜单栏Data->DataEditor-> Data Editor(Edit),将整理好的数据直接拷贝到里面,注意拷贝的时候选择首行为变量名;Excel中第1列Study不用拷贝;如下图所示:
- 返回Stata的首界面,在命令栏敲入:
network setup r n, studyvar(id) trtvar(t) format(augment) or
以上代码效应量为OR,如果是用RR作为效应量,则敲入:
network setup r n, studyvar(id) trtvar(t) format(augment) rr
结果如下图所示:
继续点击Stata菜单栏Data->Data Editor-> Data Editor(Edit),发现数据变成如下模样:
右边还有很长,实在截图不下了。
现在我们的数据就准备成可以进行网状Meta分析的格式了。
网状图
- 制作网状图,在命令栏敲入:
network map
就会跳出如下图形:
或者敲入:
network map, improve
线条以及节点的颜色、比例、以及将数字换成治疗名称,均可以在图形上点击右键,开启start graph editor后进一步编辑;或者以命令行的形式编辑;留给读者探索,在此不再赘述。
- 首先用不一致性模型进行检验,在命令栏敲入:
network meta i
成功的话会看到:
前面一堆东西不重要,主要是看红色方框里面的P值是否大于0.05;若小于0.05,则不一致性模型显著;对于这批数据不能直接用接下来的一致性模型分析。在本例中不一致性检验不显著,说明可以使用一致性模型进行分析。
- 用一致性模型进行分析,在命令栏敲入:
network meta c
结果如下所示:
B,C,D,E,F,G分别对应编码为2,3,4,5,6,7的干预,Coef就是这些干预与1(安慰剂)对比的效应量,最后三列是P值以及95%可信区间。
- 至此,一致性模型与不一致性模型的结果均已算出,在命令栏敲入:
network forest
出现如下所示的森林图,最底部是不一致性检验:
- 上面进行的不一致性检验是Global inconsistency;对于网状Meta,光做Global是不够的,还有Local inconsistency;为了做局部不一致检验,我们通常使用节点劈裂法(node-splitting method);在命令栏敲入如下代码:
network sidesplit all, tau
结果如下所示:
若P小于0.05,则认为局部存在不一致性。
- 在这一步,命令栏敲入clear;然后重复第3、4、7步;为了计算每个干预的SUCRA,在命令栏敲入以下代码:
network rank min, all zero reps(5000) gen(prob)
注意,在本例中MD越小说明排名越靠前,所以这里用min,如果效应量越大排名越靠前,那么代码应该改成“network rank max, all zero reps(5000) gen(prob)”。出现如下结果:
这个图表示每个治疗排行第几的概率。如编码为1的治疗(安慰剂)排行第2的概率最大(35.1%),以此类推。
接下来计算我们通常比较关心的SUCRA,以及顺便把编码还原为我们的治疗名称,敲入以下代码:
sucra prob*, lab(Placebo Aripiprazole Risperidone Quetiapine Olanzapine Haloperidol Paliperidone)
这里lab是label(标签)的意思,括号里按照1234567编码的顺序把治疗名称写出,以空格相隔。结果如下所示:
SUCRA值越高的排名越靠前,同时可以跳出SUCRA的图:
- 制作文献中常见的联赛表,敲入以下代码:
netleague, lab(Placebo Aripiprazole Risperidone Quetiapine Olanzapine Haloperidol Paliperidone) sort(Placebo Haloperidol Risperidone Aripiprazole Olanzapine Quetiapine Paliperidone) export (“D:\network.xlsx”) eform
其中lab还是按照1234567的顺序依次写上治疗的名称;sort是按照SUCRA的大小排序,排行第一的写在最前面;export可要可不要,它的作用是将联赛表导出到指定的路径。eform很重要,因STATA默认对分类变量的输出为对数形式,eform的作用就是把它还原为OR或者RR****。结果如下:
注意如果没有export的话,这个联赛表是个临时文件,必须再次复制保存;最后一句话提示联赛表在数据视图的最末尾,也就是最右边。即点击Stata菜单栏Data->DataEditor-> Data Editor(Edit),将下面的滚动条拉至最右边,就可以看到蜷缩在角落里瑟瑟发抖的联赛表。
将结果复制到Excel里面,尽情美化吧骚年!
两两比较的森林图
- 制作两两比较的森林图,在命令栏敲入以下代码:
intervalplot, null(1) lab(PLA ARI RIS QUE OLA HAL PAL) eform
eform****很重要;其中,null(1)设置无效线为1,还可以加入pred可以输出预测区间,留给读者自行尝试;本例跳出如下森林图:
漏斗图
- 制作漏斗图,首先将数据格式转换,敲入如下代码:
network convert pairs
可将数据转换成如下格式(瞬间感觉清爽了许多)
然后敲入如下代码:
netfunnel _y _stderr _t1 _t2 , random bycomp add(lfit _stderr _ES_CEN) noalpha
结果如图所示:
其实不用敲入这么多代码,你只敲入“netfunnel _y _stderr _t1 _t2”一样可以出结果;Stata里DIY的地方很多,读者可以敲入“help netfunnel”自行查阅帮助文档;对于其他的任何命令,都可以help一下。
- 环不一致性检测(loop inconsistency),所谓的环就是指治疗与治疗之间构成了封闭的环形。运行以下命令同样需要先将数据格式转换为清爽的格式(network convert pairs):
ifplot _y _stderr _t1 _t2 id, tau2(loop)
结果如下所示:
如果可信区间包括0,说明环不一致性不显著,但如果IF很大,说明直接比较结果和间接比较结果相差有点大……结果解释需谨慎,或者做亚组分析和回归分析找异质性来源,或者做敏感性分析等等。
- 贡献图(即观察直接比较与间接比较对最终估计结果的贡献)的制作,在命令栏敲入以下命令(需要清爽格式):
netweight _y _stderr _t1 _t2
结果如图所示:
连续型变量
假设我们已经安装好了Stata,
将要处理的数据在Excel中整理成下图所示:
其中id代表研究,t代表治疗,mean代表均数,sd是标准差,n是样本量;注意每一行代表一个研究的一个臂(组),如果一个研究有三臂,那么就占三行。分析时需将id以数字来依次编号Study。同样,依次以数字来编号t。特别注意的是,同一研究中从上到下,治疗的编码只能增大,不能降低。一般来说,将安慰剂编码为1。
- 点击Stata菜单栏Data->DataEditor-> Data Editor(Edit),将整理好的数据直接拷贝到里面,注意拷贝的时候选择首行为变量名;Excel中第1列Study不用拷贝;如下图所示:
- 返回Stata的首界面,在命令栏敲入:
network setup mean sd n, study(id) trt(t)format(augment)
默认为MD,如果是用SMD作为效应量,则敲入:
network setup mean sd n, study(id) trt(t)format(augment) smd
结果如下图所示:
继续点击Stata菜单栏Data->Data Editor-> Data Editor(Edit),发现数据变成如下模样:
右边还有很长,实在截图不下了。
现在我们的数据就准备成可以进行网状Meta分析的格式了。
网状图
- 制作网状图,在命令栏敲入:
network map
就会跳出如下图形:
或者敲入:
network map, improve
线条以及节点的颜色、比例、以及将数字换成治疗名称,均可以在图形上点击右键,开启start graph editor后进一步编辑;或者以命令行的形式编辑;留给读者探索,在此不再赘述。
- 首先用不一致性模型进行检验,在命令栏敲入:
network meta i
成功的话会看到:
前面一堆东西不重要,主要是看红色方框里面的P值是否大于0.05;若小于0.05,则不一致性模型显著;对于这批数据不能直接用接下来的一致性模型分析。在本例中不一致性检验不显著,说明可以使用一致性模型进行分析。
- 用一致性模型进行分析,在命令栏敲入:
network meta c
结果如下所示:
B,C,D,E,F,G分别对应编码为2,3,4,5,6,7的干预,Coef就是这些干预与1(安慰剂)对比的效应量,最后三列是P值以及95%可信区间。
- 至此,一致性模型与不一致性模型的结果均已算出,在命令栏敲入:
network forest
出现如下所示的森林图,最底部是不一致性检验:
- 上面进行的不一致性检验是Global inconsistency;对于网状Meta,光做Global是不够的,还有Local inconsistency;为了做局部不一致检验,我们通常使用节点劈裂法(node-splitting method);在命令栏敲入如下代码:
network sidesplit all, tau
结果如下所示:
若P小于0.05,则认为局部存在不一致性。
- 计算每个干预的SUCRA,在命令栏敲入以下代码:
network rank min, all zero reps(5000) gen(prob)
注意,在本例中MD越小说明排名越靠前,所以这里用min,如果效应量越大排名越靠前,那么代码应该改成“network rank max, all zero reps(5000) gen(prob)”。出现如下结果:
这个图表示每个治疗排行第几的概率。如编码为1的治疗(安慰剂)排行第“worst”的概率最大(49.1%),以此类推。
接下来计算我们通常比较关心的SUCRA,以及顺便把编码还原为我们的治疗名称,敲入以下代码:
sucra prob*, lab (Placebo Aripiprazole Risperidone Quetiapine Olanzapine Haloperidol Paliperidone)
这里lab是label(标签)的意思,括号里按照1234567编码的顺序把治疗名称写出,以空格相隔。结果如下所示:
SUCRA值越高的排名越靠前,同时可以跳出SUCRA的图:
- 制作文献中常见的联赛表,敲入以下代码:
netleague, lab (Placebo Aripiprazole Risperidone Quetiapine Olanzapine Haloperidol Paliperidone) sort (Risperidone Haloperidol Aripiprazole Olanzapine Quetiapine Paliperidone Placebo) export (“D:\network.xlsx”)
或者
network setup mean sd n,ref(A) study(study) trt(treatment) smd
network meta consistency
netleague
其中lab还是按照1234567的顺序依次写上治疗的名称;sort是按照SUCRA的大小排序,排行第一的写在最前面;export可要可不要,它的作用是将联赛表导出到指定的路径。结果如下:
注意如果没有export的话,这个联赛表是个临时文件,必须再次复制保存;最后一句话提示联赛表在数据视图的最末尾,也就是最右边。即点击Stata菜单栏Data->Data Editor-> Data Editor(Edit),将下面的滚动条拉至最右边,就可以看到蜷缩在角落里瑟瑟发抖的联赛表。
将结果复制到Excel里面,尽情美化吧骚年!
两两比较的森林图
- 制作两两比较的森林图,在命令栏敲入以下代码:
intervalplot, null(0) lab(Pla Ari Ris Que Ola Hal Pal)
其中,null(0)设置无效线为0,还可以加入pred可以输出预测区间,留给读者自行尝试;本例跳出如下森林图:
不得不说Stata的作图真的是棒棒的。
漏斗图
- 制作漏斗图,首先将数据格式转换,敲入如下代码:
network convert pairs
可将数据转换成如下格式(瞬间感觉清爽了许多)
然后敲入如下代码:
netfunnel _y _stderr _t1 _t2, random bycomp add(lfit _stderr _ES_CEN) noalpha
结果如图所示:
其实不用敲入这么多代码,你只敲入“netfunnel _y _stderr _t1 _t2”一样可以出结果;Stata里DIY的地方很多,读者可以敲入“help netfunnel”自行查阅帮助文档;对于其他的任何命令,都可以help一下。
- 环不一致性检测(loop inconsistency),所谓的环就是指治疗与治疗之间构成了封闭的环形。运行以下命令同样需要先将数据格式转换为清爽的格式(network convert pairs):
ifplot _y _stderr _t1 _t2 id, tau2(loop)
结果如下所示:
如果可信区间包括0,说明环不一致性不显著,但如果IF很大,说明直接比较结果和间接比较结果相差有点大……结果解释需谨慎,或者做亚组分析和回归分析找异质性来源,或者做敏感性分析等等。
- 贡献图(即观察直接比较与间接比较对最终估计结果的贡献)的制作,在命令栏敲入以下命令(需要清爽格式):
netweight _y _stderr _t1 _t2
结果如图所示:
看起来乱糟糟的,个人觉得好像也没多大用,文献中也很少出现这个图,大家看看就行。
- 当计算出各个治疗药物疗效的SUCRA以及耐受性的SUCRA时,可以将数据整理成如下格式:
然后将数据拷贝在Stata的数据里面,在命令栏输入:
clusterank efficacy tolerability t
结果如下所示:
\17. 最后说一下,在运行某一步的时候有时可能会出现莫名其妙的错误,可能与使用的是破解版有关,这时候只需要clear掉所有数据(在命令栏直接敲入clear能清空所有数据),再从Excel复制进来,直接输入想要那步的命令,多半能解决问题。
如果出现matsize too small
输入
set matsize 5000
或者
set matsize 11000