面试必问之——fs命令

1,057 阅读5分钟

导读

在我们进行数据整理的过程中,我们经常会用到循环来写程序,那如果想对某一路径下的文件或文件夹进行循环,应该怎么操作呢?我们可以用宏扩展函数或者fs命令将文件或文件夹的名称放入局部宏或返回值中,再结合循环进行操作。那么今天我们就来简单介绍一下fs命令的用法~

简单介绍一下fs命令的用法~

fs命令可以在Stata结果输出窗口输出当前文件夹下或当前目录下的文件名称(不包括文件夹和目录),也可以列示指定路径或当前路径下指定类型的文件,并将结果储存在返回值r(files)中。例如,当我们更改到确定的路径之后,如果我们想要的是dta文件,就可以用fs *.dta来获取路径下的dta文件,其中“*”为通配符,表示可以匹配任意零个、单个或多个字符(当然,文件名不能为空,所以此处表示至少有一个字符);“.dta”即表示dta文件;fs *.dta就表示遍历当前路径下的所有dta文件。

dir、list不同的是,fs命令可以给出不止一种指定类型的文件,而且fs命令还可以显示出隐藏文件。dir命令可以将文件大小、文件修改时间以及文件名称都列示在结果输出页面中。如果我们只想将文件名列示出来的话,就可以使用fs命令进行操作。

fs的命令语句为:

fs [filespec [filespec [ ... ]]]

其中filespec是一个文件名称或者是一连串文件名称,这一连串的文件名称通常用通配符*来表示。

fs命令是Stata的外部命令,如果是第一次使用,需要先进行安装。

ssc install fs

二、举例介绍

1.简单小例子

接下来先通过一些简单的小例子来说明fs命令的一些基本用法。

首先我们可以通过cntop10命令来获取民生银行(600016)、中信证券(600030)、南京高科(600064)三家上市公司的十大股东数据。

clear all
cap mkdir D:\stata16\fs命令
cd D:\stata16\fs命令
ssc install cntop10
cntop10 600016 600030 600064

码字不易废话两句:有需要python学习资料的或者有技术问题交流 “点击”即可

由下图可以看到我们得到了三家上市公司的十大股东信息,在D:\stata16\fs命令路径下也可以看到生成了三个dta文件。

图片1

图片2

此时如果我想在Stata结果输出窗口列示出当前路径下的dta文件,就可以用fs命令。

fs *.dta

如图所示,在Stata的结果输出窗口就列示出了当前路径下的dta文件名称。

图片3

那如果我们现在不在D:\stata16\fs命令这个路径下,而是在其它路径下,此时我们想直接得到这个路径下的dta文件,fs命令可以实现吗?当然可以!这时直接在程序中加上文件所在的路径即可。下边我们先更改一下路径,然后直接在fs命令后跟上文件所在的路径名称和所需要的文件类型来试一试。

cd D:\
fs D:\stata16\fs命令\*.dta

如图所示,同样可以得到相应路径下的dta文件名称

图片4

如果我们想同时列示出当前路径下的dta文件和其它类型的文件,我们也可以使用fs命令。比如除了dta文件,我还想同时列示出当前路径下的do文件,那我也可以使用fs命令进行操作。

cd D:\stata16\fs命令
fs *.dta *.do

可以看到,在Stata结果输出窗口就同时列示出了当前路径下的dta文件和do文件。 
图片5

如果想得到其它类型的文件,直接更换文件后缀即可,如 *.txt、 *.xlsx、 *.csv等等。

2.fs命令与循环结合使用

如果想将这三家上市公司的十大股东信息dta文件合并起来,应该怎么操作呢?大家可能较为熟悉的是通过宏扩展函数结合循环进行操作,但是这里通过前边介绍的fs命令也可以实现。

cd D:\
fs D:\stata16\fs命令\*.dta

Stata结果输出窗口列示出了当前路径下的dta文件,即我们所需要合并的三家上市公司十大股东信息的dta文件。

图片6

return list

我们可以看出当前路径下的dta文件被放在一个r(files)里。

图片 7

接下来就可以通过循环合并dta文件了。

clear
foreach file in `r(files)' {
  append using `file'
  }

如图所示,三家上市公司的十大股东信息文件就合并成功啦!

图片8

以上就是小编今天为大家带来的内容,小编本身就是一名python开发工程师,我自己花了三天时间整理了一套python学习教程,从最基础的python脚本到web开发,爬虫,数据分析,数据可视化,机器学习,等,这些资料有想要的小伙伴 :" 点击 " 即可领取