大家好,又见面了,我是你们的朋友全栈君。
任务介绍
VBA编程中,为了程序的灵活性,有时候需要用到用户交互操作,例如让用户选择一个文件夹,用户选择一个单元格等等。本文将介绍一些常用的用户交互操作的实现
选择文件夹
St = Application.FileDialog(msoFileDialogFolderPicker).Show '如果选择了文件夹就返回-1,不选择文件夹就返回0
If St <> 0 Then
fileDir = Application.FileDialog(msoFileDialogFolderPicker).SelectedItems(1) '取选择的文件夹路径
MsgBox "您选择的文件夹是:" & fileDir
Else
Exit Sub '没有选择合并文件所在路径,退出程序
End If
选择文件保存路径
Dim fileSaveName
'保存文件所在路径
fileSaveName = Application.GetSaveAsFilename(InitialFileName:="合并.xlsx", fileFilter:="Text Files (*.xlsx), *.xlsx")
If fileSaveName <> False Then
MsgBox "Save as " & fileSaveName
Else
Exit Sub '没有选择保存路径,退出程序
End If
'创建空白excel文件
Set cwb = Workbooks.Add
cwb.SaveAs fileName:=fileSaveName, _
FileFormat:=xlOpenXMLWorkbook, CreateBackup:=False
交互选择一列
'下面通过InputBox这个方法确定分组项所在的列
On Error GoTo 100 '如果有错误跳转到100处
Set Rg = Application.InputBox("请选择分组项所在的列(可以单击其中一个单元格)", "选择", Type:=8) '用了这句不可以关闭屏幕刷新
ColNum = Rg.Column '把要拆分的列赋值变量 ColNum
Sheets(Rg.Parent.Name).Activate '将选择的工作表设置为活动工作表
100:
MsgBox "您选择了取消或者是关闭,即将退出程序", 64, "温馨提示"
交互选择一行
'下面通过InputBox这个方法确定数据(表头、列标题除外)开始所在的行
On Error GoTo 100 '如果有错误跳转到100处
Set Rg = Application.InputBox("请选择标题所在的行(可以单击其中一个单元格)", "选择", Type:=8) '用了这句不可以关闭屏幕刷新
RowNum = Rg.Row '把数据开始的行赋值变量 RowNum
100:
MsgBox "您选择了取消或者是关闭,即将退出程序", 64, "温馨提示"
发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/136842.html原文链接:https://javaforall.cn
【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛
【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...