VFP_获得给定目录下所有文件夹路径-非递归方法(转)

FUNCTION GetAllPath
LPARAMETERS tcRoot
LOCAL ARRAY laDirs[1],aDirCount[1]
LOCAL i, n, m, lnRec, lcTblDir, lcDir, lnCount, lnSelect, lcPathStr

lnSelect = SELECT()

lcTblDir= SYS(2015)
CREATE CURSOR &lcTblDir (fldsn I(3),flddir C(200))
INSERT INTO &lcTblDir. (fldsn,flddir) VALUES (0,SUBSTR(tcRoot,1,LEN(tcRoot)-1))

i = 0
m = LEN(tcRoot)+1
lcPathStr = ""
DO WHILE .T.
SELECT COUNT(*) FROM (lcTblDir) WHERE fldSn=i INTO ARRAY aDirCount
IF aDirCount(1)=0
EXIT
ENDIF
SELECT (lcTblDir)
SCAN FOR fldSn=i
lcDir = ALLTRIM(flddir) + "\"
lnCount = ADIR(laDirs,lcDir + "*.", "D")
lnRec = RECNO()
FOR n = 1 TO lnCount
IF !("." $ laDirs(n,1) OR ".." $ laDirs(n,1))
INSERT INTO &lcTblDir. (fldsn,flddir) VALUES (i+1,lcDir+laDirs(n,1))
lcPathStr = lcPathStr + IIF(EMPTY(lcPathStr),"",",") + SUBSTR(ALLTRIM(flddir),m)
ENDIF
ENDFOR
GO lnRec IN (lcTblDir)
ENDSCAN
i=i+1
ENDDO

SELECT (lnSelect)
RETURN lcTblDir
ENDFUNC

一、用法:

lcPathDBF = GetAllPath("c:\") 
SELECT (lcPathDBF)
BROWSE

二、如果将最后一句改为“RETURN lcPathStr”可以得到给定目录下的所有文件夹相对路径(逗号隔开),这样有一个应用,可以动态设置搜索路径:

lcPath=GetAllPath("c:\我的应用程序\") 
SET PATH to &lcPath

以上方法有个好处,你随便移动数据表、表单或其他文件的位置,系统不会出现找不到文件的错误。新建文件夹时也会将其自动加到搜索路径中,这个方法在我的程序中已经成功应用。代码如下(代码放到主程序最开始部分,主程序文件应放到应用程序文件夹的第一层):

*-----------------------------------

lcSys16 = SYS(16) &&查询当前运行程序名
lcProgram = SUBSTR(lcSys16, AT(":", lcSys16) - 1)
cDefaultPath=LEFT(lcProgram, RAT("\", lcProgram))
CD LEFT(lcProgram, RAT("\", lcProgram)) &&设置默认路径

cSubDir = GetAllPath(cDefaultPath)
SET PATH TO &cSubDir. ADDITIVE &&设置搜索路径

*-----------------------------------





  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值