vbs,hta中选择文件夹对话框实现代码
来源:易贤网 阅读:1659 次 日期:2016-07-18 15:16:43
温馨提示:易贤网小编为您整理了“vbs,hta中选择文件夹对话框实现代码”,方便广大网友查阅!

在vbs中选择文件夹可以直接调用系统的文件夹对话框

代码如下:

on error resume next

SelectFolder

function SelectFolder()

Const MY_COMPUTER = &H11&

Const WINDOW_HANDLE = 0

Const OPTIONS = 0

Set objShell = CreateObject("Shell.Application")

Set objFolder = objShell.Namespace(MY_COMPUTER)

Set objFolderItem = objFolder.Self

strPath = objFolderItem.Path

Set objShell = CreateObject("Shell.Application")

Set objFolder = objShell.BrowseForFolder(WINDOW_HANDLE, "选择文加夹:", OPTIONS, strPath)

If objFolder Is Nothing Then

msgbox "您没有选择任何有效目录!"

End If

Set objFolderItem = objFolder.Self

objPath = objFolderItem.Path

msgbox "您选择的文件夹是:" & objPath

end function

但是这个代码不能在hta里用,原因是权限不够,不知道其它机子上能不能。

于是写了个用vbs自带函数和fso结合的文件夹选择代码,仅供参考

代码如下:

<script language=vbscript>

dim spath

spath="Root"

function SFolder()

on error resume next

Dim fso, drv, f, fc, nf, s, i, p, r, d

i=3

if spath="Root" then

Set fso =CreateObject("Scripting.FileSystemObject")

Set drv =fso.Drives

s="输入序号为进入,序号+#为选中(c为取消)"+chr(13)+chr(10)

s=s+"1.根目录"+chr(13)+chr(10)

s=s+"2.上层"+chr(13)+chr(10)

For Each a In drv

s=s+cstr(i)+"."+ a.Path+chr(13)+chr(10)

i=i+1

Next

GetD s

else

Set fso =CreateObject("Scripting.FileSystemObject")

if right(spath,1)<>"\" then

spath=spath+"\"

end if

Set fc =fso.GetFolder(spath).SubFolders

s="输入序号为进入,序号+#为选中(c为取消)"+chr(13)+chr(10)

s=s+"1.根目录"+chr(13)+chr(10)

s=s+"2.上层"+chr(13)+chr(10)

for each nf in fc

s=s+cstr(i)+"."+nf+chr(13)+chr(10)

i=i+1

next

GetF s

end if

end function

function GetD(s)

on error resume next

p=inputbox(s,"","")

if p="c" then

exit function

end if

r=split(s,chr(13)+chr(10))

if right(p,1)="#" then

if left(p,len(p)-1)=1 then

msgbox "这是根目录,不能选择根目录!"

GetD s

elseif left(p,len(p)-1)=2 then

msgbox "这是根目录,不能选择根目录!"

GetD s

else

d=split(r(left(p,len(p)-1)),".")

msgbox "选择:" & d(1)

Document.forms("ValidForm").FPath.Value=d(1)

spath="Root"

end if

else

if p=1 then

msgbox "已经是根目录!"

GetD s

elseif p=2 then

msgbox "已经是最上层!"

GetD s

else

d=split(r(p),".")

spath=d(1)

'msgbox "进入:" & d(1)

SFolder

end if

end if

end function

function GetF(s)

on error resume next

p=inputbox(s,"","")

if p="c" then

exit function

end if

r=split(s,chr(13)+chr(10))

if right(p,1)="#" then

if left(p,len(p)-1)=1 then

msgbox "这是根目录,不能选择根目录!"

GetD s

elseif left(p,len(p)-1)=2 then

GetTheParent =CreateObject("Scripting.FileSystemObject").GetParentFolderName(spath)

msgbox "选择:" & GetTheParent

Document.forms("ValidForm").FPath.Value=GetTheParent

else

d=split(r(left(p,len(p)-1)),".")

msgbox "选择:" & d(1)

Document.forms("ValidForm").FPath.Value=d(1)

spath="Root"

end if

else

if p=1 then

spath="Root"

SFolder

elseif p=2 then

GetTheParent =CreateObject("Scripting.FileSystemObject").GetParentFolderName(spath)

if GetTheParent="" then

spath="Root"

'msgbox "进入:根目录"

else

spath=GetTheParent

'msgbox "进入:" & GetTheParent

end if

SFolder

else

d=split(r(p),".")

spath=d(1)

'msgbox "进入:" & d(1)

SFolder

end if

end if

end function

</script>

<form id="ValidForm" method="POST" action="--WEBBOT-SELF--">

<p><input type="text" name="FPath" size="50" onclick="PastePath"><input type="button" value="选择文件夹" name="SelFolder" onclick="SFolder"></p>

</form>

更多信息请查看脚本栏目
由于各方面情况的不断调整与变化,易贤网提供的所有考试信息和咨询回复仅供参考,敬请考生以权威部门公布的正式信息和咨询为准!

2025国考·省考课程试听报名

  • 报班类型
  • 姓名
  • 手机号
  • 验证码
关于我们 | 联系我们 | 人才招聘 | 网站声明 | 网站帮助 | 非正式的简要咨询 | 简要咨询须知 | 加入群交流 | 手机站点 | 投诉建议
工业和信息化部备案号:滇ICP备2023014141号-1 云南省教育厅备案号:云教ICP备0901021 滇公网安备53010202001879号 人力资源服务许可证:(云)人服证字(2023)第0102001523号
云南网警备案专用图标
联系电话:0871-65099533/13759567129 获取招聘考试信息及咨询关注公众号:hfpxwx
咨询QQ:526150442(9:00—18:00)版权所有:易贤网
云南网警报警专用图标