Solved

How to pass parameters in vbscript

Posted on 2008-10-09
8
1,894 Views
Last Modified: 2012-06-27
Hi,
i want to write a stand alone vbscript that get 5 numbers and return 2 results, the sum and the multipling of this 5 numbers. i need to run this vbscript from java code and use the return results.
please help me with tha vbscript and the java code (include use the return parameters).
Thanks.
0
Comment
Question by:ExpandNetworks
  • 5
  • 3
8 Comments
 
LVL 65

Expert Comment

by:RobSampson
ID: 22682172
Hi, the only way that I can think of to do this is to pass the five numbers to the VBScript, as well as another argument that specifies whether you want to sum or multiply those numbers.  VBScript is only capable of returning one integer value at a time.

Here is the VBS that will do the calculation for you.  The first parameter must be a string of "sum" or "multiply".  The rest of the parameters can be 1 or more integers.

Regards,

Rob.

If WScript.Arguments.Count > 1 Then

	strMode = WScript.Arguments.Item(0)

	If LCase(strMode) = LCase("sum") Then

		intTotal = 0

	ElseIf LCase(strMode) = LCase("multiply") Then

		intTotal = 1

	End If

	For intArg = 1 To WScript.Arguments.Count - 1

		If LCase(strMode) = LCase("sum") Then

			intTotal = intTotal + CInt(WScript.Arguments.Item(intArg))

		ElseIf LCase(strMode) = LCase("multiply") Then

			intTotal = intTotal * CInt(WScript.Arguments.Item(intArg))

		End If

	Next

	WScript.Quit(intTotal)

Else

	WScript.Echo "There were not enough arguments passed to this script."

End If

Open in new window

0
 
LVL 65

Expert Comment

by:RobSampson
ID: 22682180
And this is a VBS implementation of how to call that function......I'm not that familiar with JavaScript, but perhaps this will help you create a JavaScript version, if you know it....

Regards,

Rob.
Set objShell = CreateObject("WScript.Shell")

strVBS = "C:\Temp\Scripts\Test1.vbs"

'strMode = "sum"

strMode = "multiply"

arrNumbers = Array(1,2,3,4,5)
 

strCommand = "wscript " & strVBS & " " & strMode

For Each intNum In arrNumbers

	strCommand = strCommand & " " & intNum

Next
 

strReturn = objShell.Run(strCommand, 1, True)

MsgBox strReturn

Open in new window

0
 

Author Comment

by:ExpandNetworks
ID: 22688115
It is possible to return a string or an array instad of only one integer?
0
 
LVL 65

Expert Comment

by:RobSampson
ID: 22691392
No, not without writing that value to a file or environment variable for the other script to read from.

The wscript.quit method is only capable of returning a single integer value.

If you want the VBScript to write to a file, for the JavaScript to pick up later, than can be done....

Regards,

Rob.
0
Is Your Active Directory as Secure as You Think?

More than 75% of all records are compromised because of the loss or theft of a privileged credential. Experts have been exploring Active Directory infrastructure to identify key threats and establish best practices for keeping data safe. Attend this month’s webinar to learn more.

 

Author Comment

by:ExpandNetworks
ID: 22694474
so,
how can i use the environment variable?
can you please show me an example?
Thanks
0
 
LVL 65

Accepted Solution

by:
RobSampson earned 250 total points
ID: 22699100
Hi, well, again, I'm not sure about a JavaScript implementation, but in VBScript, you can use the following code.

In the links in the comments, there is a slight alternative to this method for accessing environment variables as well.

Regards,

Rob.
strEnvVarName = "MakeRuleReturnCode"

Set_Env_Var strEnvVarName, "0"

strVarValue = Get_Env_Var(strEnvVarName)
 

MsgBox strEnvVarName & " currently has a value of " & strVarValue
 

Sub Set_Env_Var(strVarName, strVarValue)
 

	' SOURCE: http://www.codecomments.com/archive299-2005-12-736281.html

	' HOW TO ECHO???: http://msdn.microsoft.com/library/default.asp?url=/library/en-us/script56/html/05426477-f6e4-4dcb-8101-3f7d979c8ed5.asp

	Dim objShell, objEnvVar

	Set objShell = CreateObject("WScript.Shell")

	Set objEnvVar = objShell.Environment("Volatile")

	objEnvVar(strVarName) = strVarValue

	Set objEnvVar = Nothing

	Set objShell = Nothing

	

End Sub
 

'*************************************************************
 

Function Get_Env_Var(strVarName)
 

	' SOURCE: http://www.codecomments.com/archive299-2005-12-736281.html

	' HOW TO ECHO???: http://msdn.microsoft.com/library/default.asp?url=/library/en-us/script56/html/05426477-f6e4-4dcb-8101-3f7d979c8ed5.asp

	Dim objShell, objEnvVar

	Set objShell = CreateObject("WScript.Shell")

	Set objEnvVar = objShell.Environment("Volatile")

	Get_Env_Var = objEnvVar(strVarName)

	Set objEnvVar = Nothing

	Set objShell = Nothing

	

End Function

Open in new window

0
 

Author Closing Comment

by:ExpandNetworks
ID: 31504719
Thanks, Rob
It's was very helpfull.....
Thanks again.
0
 
LVL 65

Expert Comment

by:RobSampson
ID: 22706867
No problem. Thanks for the grade. I hope you can find a JavaScript equivalent....

Rob.
0

Featured Post

Is Your Active Directory as Secure as You Think?

More than 75% of all records are compromised because of the loss or theft of a privileged credential. Experts have been exploring Active Directory infrastructure to identify key threats and establish best practices for keeping data safe. Attend this month’s webinar to learn more.

Question has a verified solution.

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

Suggested Solutions

In this post we will learn how to connect and configure Android Device (Smartphone etc.) with Android Studio. After that we will run a simple Hello World Program.
Basic understanding on "OO- Object Orientation" is needed for designing a logical solution to solve a problem. Basic OOAD is a prerequisite for a coder to ensure that they follow the basic design of OO. This would help developers to understand the b…
Viewers learn about the “for” loop and how it works in Java. By comparing it to the while loop learned before, viewers can make the transition easily. You will learn about the formatting of the for loop as we write a program that prints even numbers…
This video teaches viewers about errors in exception handling.

911 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

Need Help in Real-Time?

Connect with top rated Experts

20 Experts available now in Live!

Get 1:1 Help Now