开发者

How to get the excel file name / path in VBA

开发者 https://www.devze.com 2022-12-14 08:47 出处:网络
Say, I\'m writing a VBA inside my excel file sample.xls. Now I want to get the full path开发者_开发百科 of sample.xls in my VBA. How do I do it?If you mean VBA, then you can use FullName, for example:

Say, I'm writing a VBA inside my excel file sample.xls. Now I want to get the full path开发者_开发百科 of sample.xls in my VBA. How do I do it?


If you mean VBA, then you can use FullName, for example:

strFileFullName = ThisWorkbook.FullName

(updated as considered by the comments: the former used ActiveWorkbook.FullName could more likely be wrong, if other office files may be open(ed) and active. But in case you stored the macro in another file, as mentioned by user @user7296559 here, and really want the file name of the macro-using file, ActiveWorkbook could be the correct choice, if it is guaranteed to be active at execution time.)


this is a simple alternative that gives all responses, Fullname, Path, filename.

Dim FilePath, FileOnly, PathOnly As String

FilePath = ThisWorkbook.FullName
FileOnly = ThisWorkbook.Name
PathOnly = Left(FilePath, Len(FilePath) - Len(FileOnly))


   strScriptFullname = WScript.ScriptFullName 
   strScriptPath = Left(strScriptFullname, InStrRev(strScriptFullname,"\")) 


If you need path only this is the most straightforward way:

PathOnly = ThisWorkbook.Path


if you need path only without file name:

ActiveWorkbook.Path

it would return D:\Folder

if you need file path with file name also:

ActiveWorkbook.FullName

it would return D:\Folder\sample.xls

if you need file name only:

ActiveWorkbook.Name

it would return sample.xls

so if you want combine file path and file name to get full directory don't forget to add "" between. otherwise its simpler using .Path


ActiveWorkbook.FullName would be better I think, in case you have the VBA Macro stored in another Excel Workbook, but you want to get the details of the Excel you are editing, not where the Macro resides.

If they reside in the same file, then it does not matter, but if they are in different files, and you want the file where the Data is rather than where the Macro is, then ActiveWorkbook is the one to go for, because it deals with both scenarios.


There is a universal way to get this:

Function FileName() As String
    FileName = Mid(Application.Caption, 1, InStrRev(Application.Caption, "-") - 2)
End Function
0

精彩评论

暂无评论...
验证码 换一张
取 消