Solved

VBScript get self and parent folder name

Posted on 2009-04-01
1
11,007 Views
Last Modified: 2012-05-06
I'm overlooking somethign here. This script is saved as "location.vbs" and returns the name of the folder that location.vbs is in when run, and the parent folder. It works correctly when placed in any folder at least 3 directories down from the root, but fails on anything one or two directories from the root.

I'm having a brain-fade as to why. I need this to give me the name of the folder (note, NOT the path, just the folder name) that the script is sitting in when run, regardless of where that is. (The script will be moved, so it can't be hard-coded) and the name of the parent folder (if any, or null if the script is on root.)

Dim filesys
Set filesys = CreateObject("Scripting.FileSystemObject")
varPathCurrent = filesys.GetParentFolderName(WScript.ScriptFullName)
varPathParent = filesys.GetParentFolderName(varPathCurrent)
varPathGrandParent = filesys.GetParentFolderName(varPathParent)

varNameFolderCurrent = mid(varPathCurrent, len(varPathParent) + 2 , len(varPathCurrent) - len(varPathParent) - 1)
varNameFolderParent = mid(varPathCurrent, len(varPathGrandParent) + 2 , len(varPathCurrent) - len(varPathGrandParent) - len(varNameFolderCurrent) - 2)

msgbox varNameFolderCurrent & vbCrLf & varNameFolderParent
0
Comment
Question by:mcj
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
1 Comment
 
LVL 65

Accepted Solution

by:
RobSampson earned 125 total points
ID: 24044771
Hi there.

See if this works for you.

Regards,

Rob.
Dim filesys
Set filesys = CreateObject("Scripting.FileSystemObject")
varPathCurrent = filesys.GetParentFolderName(WScript.ScriptFullName)
varPathParent = filesys.GetParentFolderName(varPathCurrent)
varPathGrandParent = filesys.GetParentFolderName(varPathParent)
 
If filesys.FolderExists(varPathCurrent) Then
	If InStrRev(varPathCurrent, "\") < Len(varPathCurrent) Then
		varPathCurrent = Mid(varPathCurrent, InStrRev(varPathCurrent, "\") + 1)
	Else
		varPathCurrent = Left(varPathCurrent, Len(varPathCurrent) - 1)
	End If
Else
	varPathCurrent = ""
End If
 
If filesys.FolderExists(varPathParent) Then
	If InStrRev(varPathParent, "\") < Len(varPathParent) Then
		varPathParent = Mid(varPathParent, InStrRev(varPathParent, "\") + 1)
	Else
		varPathParent = Left(varPathParent, Len(varPathParent) - 1)
	End If
Else
	varPathParent = ""
End If
 
msgbox varPathCurrent & vbCrLf & varPathParent

Open in new window

0

Featured Post

Industry Leaders: We Want Your Opinion!

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

I met Paul Devereux (@pdevereux) today when I responded to his tweet asking “Anybody know how to automate adding files from disk to a folder in #outlook  ?”.  I replied back and told Paul that using automation, in this case scripting, to add files t…
When it comes to writing scripts for a Client/Server computing environment it is essential to consider some way of enabling the authentication functionality within a script. This sort of consideration mainly comes into the picture when we are dealin…
A short tutorial showing how to set up an email signature in Outlook on the Web (previously known as OWA). For free email signatures designs, visit https://www.mail-signatures.com/articles/signature-templates/?sts=6651 If you want to manage em…

710 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question