fopetesl Posted June 5, 2017 Posted June 5, 2017 (edited) I have several batch files, e.g. echo off echo !DT | ncat 192.168.1.6 80 > scan1.dta This data1.bat works as expected by saving data from !DT command. I have tried several variations from AutoIt ; $DOS = RunWait(@ComSpec & " /k " & "ncat 192.168.1.6 80 <getdata >scan1.dta", "", @SW_HIDE, $STDERR_CHILD + $STDOUT_CHILD) ; $DOS = Run(@ComSpec & " /k " & "ncat 192.168.1.6 80 <getdata >scan1.dta", "", @SW_HIDE, $STDERR_CHILD + $STDOUT_CHILD) ; $DOS = Run(@ComSpec & " /c " & "echo ?DT | ncat 192.168.1.6 80 > scan1.dta & @CRLF", "", @SW_HIDE, $STDERR_CHILD + $STDOUT_CHILD) $DOS = Run(@ComSpec & " /c " & "data1.bat & @CRLF", "", @SW_HIDE, $STDERR_CHILD + $STDOUT_CHILD) but none save the data to scan1.dta Run out of ideas so far... Edited June 5, 2017 by fopetesl Missing code The most powerful number in the Universe. Zero.
Developers Jos Posted June 5, 2017 Developers Posted June 5, 2017 Are you sure you are looking in the right subdirectory ? Why do you have the @CRLF in there ? You don't need to give a Enter when running a script! Run it as test like this and see what directory it is in and whether there is an error: $DOS = Run(@ComSpec & " /k " & "data1.bat", "", default, $STDERR_CHILD + $STDOUT_CHILD) Jos SciTE4AutoIt3 Full installer Download page - Beta files Read before posting How to post scriptsource Forum etiquette Forum Rules Live for the present, Dream of the future, Learn from the past.
fopetesl Posted June 5, 2017 Author Posted June 5, 2017 No change, Jos. Not sure what you mean by "see what directory it is in" since although the command prompt windows flashes up it isn't long enough to take note. I can see that the scan1.dta files has been opened since the timestamp has been updated but it contains no data. I also did a search of the whole drive in case scan1.dta was placed somewhere else. The most powerful number in the Universe. Zero.
Developers Jos Posted June 5, 2017 Developers Posted June 5, 2017 The command line I gave should remain open since it uses /K . Did you use it as I type it? Jos SciTE4AutoIt3 Full installer Download page - Beta files Read before posting How to post scriptsource Forum etiquette Forum Rules Live for the present, Dream of the future, Learn from the past.
fopetesl Posted June 5, 2017 Author Posted June 5, 2017 Still the same, Jos. syntax as you suggested: $DOS = Run(@ComSpec & " /k " & "data1.bat", "", @SW_HIDE, $STDERR_CHILD + $STDOUT_CHILD) The most powerful number in the Universe. Zero.
Moderators JLogan3o13 Posted June 5, 2017 Moderators Posted June 5, 2017 (edited) The /k should keep the command window open, does it? If so, which directory is it showing? "Still the same" is not answering the question that Jos has asked twice now. Edited June 5, 2017 by JLogan3o13 "Profanity is the last vestige of the feeble mind. For the man who cannot express himself forcibly through intellect must do so through shock and awe" - Spencer W. Kimball How to get your question answered on this forum!
Developers Jos Posted June 5, 2017 Developers Posted June 5, 2017 (edited) 15 minutes ago, fopetesl said: Still the same, Jos. syntax as you suggested: $DOS = Run(@ComSpec & " /k " & "data1.bat", "", @SW_HIDE, $STDERR_CHILD + $STDOUT_CHILD) This is NOT the commandline I provide! Check for the difference. Jos Edited June 5, 2017 by Jos SciTE4AutoIt3 Full installer Download page - Beta files Read before posting How to post scriptsource Forum etiquette Forum Rules Live for the present, Dream of the future, Learn from the past.
fopetesl Posted June 5, 2017 Author Posted June 5, 2017 (edited) Sorry. Too many balls in the air. No. Windows does not stay open even with corrected syntax. $DOS = Run(@ComSpec & " /k " & "data1.bat", "", default, $STDERR_CHILD + $STDOUT_CHILD) Edited June 5, 2017 by fopetesl add code The most powerful number in the Universe. Zero.
MattHiggs Posted June 5, 2017 Posted June 5, 2017 31 minutes ago, fopetesl said: Sorry. Too many balls in the air. No. Windows does not stay open even with corrected syntax. $DOS = Run(@ComSpec & " /k " & "data1.bat", "", default, $STDERR_CHILD + $STDOUT_CHILD) Well part of the problem that I believe that @Jos is trying to get to is that you are not specifying the directory in which the file is located. The only case in which you wouldn't have to is if the script that you are running is in the same directory as the file you are trying to interact with. If it is not, then that would be the issue: the script has no idea where the file is, because it is only looking in the current working directory (aka the directory in which the script is located). You need to specify where the file is located in the "working Directory parameter. Using the code you provided: $DOS = Run(@ComSpec & " /k " & "data1.bat", "Path\To\Folder\Containing\file", default, $STDERR_CHILD + $STDOUT_CHILD)
Developers Jos Posted June 5, 2017 Developers Posted June 5, 2017 The simple point I am getting to is that I think the CMD prompt should stay open when /k is used so you can see any error and the workdir it is in. When that is not the case try an even simpler version to understand some of the basics: $DOS = Run(@ComSpec & " /k " & "data1.bat") Jos SciTE4AutoIt3 Full installer Download page - Beta files Read before posting How to post scriptsource Forum etiquette Forum Rules Live for the present, Dream of the future, Learn from the past.
BrewManNH Posted June 5, 2017 Posted June 5, 2017 Is there any reason, other than having to rewrite them, that you can't get rid of the batch files entirely and just do everything with AutoIt? If I posted any code, assume that code was written using the latest release version unless stated otherwise. Also, if it doesn't work on XP I can't help with that because I don't have access to XP, and I'm not going to.Give a programmer the correct code and he can do his work for a day. Teach a programmer to debug and he can do his work for a lifetime - by Chirag GudeHow to ask questions the smart way! I hereby grant any person the right to use any code I post, that I am the original author of, on the autoitscript.com forums, unless I've specifically stated otherwise in the code or the thread post. If you do use my code all I ask, as a courtesy, is to make note of where you got it from. Back up and restore Windows user files _Array.au3 - Modified array functions that include support for 2D arrays. - ColorChooser - An add-on for SciTE that pops up a color dialog so you can select and paste a color code into a script. - Customizable Splashscreen GUI w/Progress Bar - Create a custom "splash screen" GUI with a progress bar and custom label. - _FileGetProperty - Retrieve the properties of a file - SciTE Toolbar - A toolbar demo for use with the SciTE editor - GUIRegisterMsg demo - Demo script to show how to use the Windows messages to interact with controls and your GUI. - Latin Square password generator
Developers Jos Posted June 5, 2017 Developers Posted June 5, 2017 A quick test revealed indeed that nothing was shown with the STDERR and STDOUT parameters. These 2 give the same result and show me an error message. The first one as console output and the second in the CMD prompt: #include <AutoItConstants.au3> $DOS = Run(@ComSpec & " /k " & "data1.bat", "", default, $STDERR_CHILD + $STDOUT_CHILD) ; Wait until the process has closed using the PID returned by Run. ProcessWaitClose($DOS) ; Read the Stdout stream of the PID returned by Run. This can also be done in a while loop. Look at the example for StderrRead. ConsoleWrite('@@ Debug(' & @ScriptLineNumber & ') : StdoutRead($iPID) = ' & StdoutRead($DOS) & @CRLF ) ;### Debug Console ConsoleWrite('@@ Debug(' & @ScriptLineNumber & ') : StdoutRead($iPID) = ' & StderrRead($DOS) & @CRLF ) ;### Debug Console ; $DOS2 = Run(@ComSpec & " /k " & "data1.bat") Jos Skysnake 1 SciTE4AutoIt3 Full installer Download page - Beta files Read before posting How to post scriptsource Forum etiquette Forum Rules Live for the present, Dream of the future, Learn from the past.
fopetesl Posted June 5, 2017 Author Posted June 5, 2017 MattHiggs, I tried your suggestion some while back which didn't resolve the issue. note also Global $BatchDir = "C:\ncat\" is at top of file. BrewMan. I'd love to include these in my script but my tiny brain can't figure out how to pipe commands to ncat.exe and collect any return data. Oddly though some .bat files do work and send a response I'd expect, e.g. Run(@ComSpec & " /k " & "IsHome.bat", "", @SW_HIDE) Sleep(400) Local $hFileOpen = FileOpen("homerep", $FO_BINARY) Local $sFileRead = FileRead($hFileOpen) FileClose($hFileOpen) Local $sStr = StringTrimLeft(StringToBinary("?HMO"), 4) If StringInStr($sFileRead, $sStr) Then MsgBox(0, "", "Head Home", 2) return(0) EndIf This just checks the (same) machine earlier in the script for scanning head at 'home' position. The only difference I can see between the working script and the failure is the amount of data returned. "?HMO" returns eight characters, data1.bat returns 754 hex bytes which it does from command prompt but just creates an empty file from AutoIt. Jos, I'll get to your read output/errors in a while, (I hope), still have balls in the air. The most powerful number in the Universe. Zero.
MattHiggs Posted June 6, 2017 Posted June 6, 2017 9 hours ago, fopetesl said: MattHiggs, I tried your suggestion some while back which didn't resolve the issue. note also Global $BatchDir = "C:\ncat\" is at top of file. BrewMan. I'd love to include these in my script but my tiny brain can't figure out how to pipe commands to ncat.exe and collect any return data. Oddly though some .bat files do work and send a response I'd expect, e.g. Run(@ComSpec & " /k " & "IsHome.bat", "", @SW_HIDE) Sleep(400) Local $hFileOpen = FileOpen("homerep", $FO_BINARY) Local $sFileRead = FileRead($hFileOpen) FileClose($hFileOpen) Local $sStr = StringTrimLeft(StringToBinary("?HMO"), 4) If StringInStr($sFileRead, $sStr) Then MsgBox(0, "", "Head Home", 2) return(0) EndIf This just checks the (same) machine earlier in the script for scanning head at 'home' position. The only difference I can see between the working script and the failure is the amount of data returned. "?HMO" returns eight characters, data1.bat returns 754 hex bytes which it does from command prompt but just creates an empty file from AutoIt. Jos, I'll get to your read output/errors in a while, (I hope), still have balls in the air. So are you setting $batchdir as the working directory in the run function? $DOS = Run(@ComSpec & " /k " & "data1.bat", $batchdir, default, $STDERR_CHILD + $STDOUT_CHILD) If this is the case, you need to get rid of the last "\" so that $batchdir = "C:\ncat" when you put the last "\" at the end of the directory path, the variable no longer equals the parent directory.
fopetesl Posted June 6, 2017 Author Posted June 6, 2017 MattHiggs. VERY carefully followed your suggestions. No change. Still have empty scan1.dta but file timestamp is updated to current. Same applies to RunWait() except it takes several seconds before Command Prompt window flashes very briefly before returning to GUI Tab. So the .dta file is clearly opened and closed without having data written. What is the difference between Run() and ShellExecute()? The most powerful number in the Universe. Zero.
anthonyjr2 Posted June 6, 2017 Posted June 6, 2017 3 hours ago, fopetesl said: What is the difference between Run() and ShellExecute()? ShellExecute() runs a program with its default interpreter. For example executing a word document would automatically open Microsoft Word. Run is usually used to run more specific programs with an exact path. They are very similar but can have slightly different use cases. I've also heard that Run is generally faster because it doesn't have to go through a separate API. If you want some more information I found this thread that explains it some more. UHJvZmVzc2lvbmFsIENvbXB1dGVyZXI=
Developers Jos Posted June 6, 2017 Developers Posted June 6, 2017 On 2017-6-5 at 5:35 PM, fopetesl said: Jos, I'll get to your read output/errors in a while, (I hope), still have balls in the air. .... and? SciTE4AutoIt3 Full installer Download page - Beta files Read before posting How to post scriptsource Forum etiquette Forum Rules Live for the present, Dream of the future, Learn from the past.
fopetesl Posted June 7, 2017 Author Posted June 7, 2017 (edited) On 05/06/2017 at 3:25 PM, Jos said: A quick test revealed indeed that nothing was shown with the STDERR and STDOUT parameters. These 2 give the same result and show me an error message. The first one as console output and the second in the CMD prompt: #include <AutoItConstants.au3> $DOS = Run(@ComSpec & " /k " & "data1.bat", "", default, $STDERR_CHILD + $STDOUT_CHILD) ; Wait until the process has closed using the PID returned by Run. ProcessWaitClose($DOS) ; Read the Stdout stream of the PID returned by Run. This can also be done in a while loop. Look at the example for StderrRead. ConsoleWrite('@@ Debug(' & @ScriptLineNumber & ') : StdoutRead($iPID) = ' & StdoutRead($DOS) & @CRLF ) ;### Debug Console ConsoleWrite('@@ Debug(' & @ScriptLineNumber & ') : StdoutRead($iPID) = ' & StderrRead($DOS) & @CRLF ) ;### Debug Console ; $DOS2 = Run(@ComSpec & " /k " & "data1.bat") Jos Jos, not sure what I actually see >"C:\Program Files (x86)\AutoIt3\SciTE\..\autoit3.exe" /ErrorStdOut "C:\S3_GUI\HauterS3 with_Tabs1.au3" @@ Debug(211) : StdoutRead($iPID) = C:\ncat>echo off C:\ncat> @@ Debug(212) : StdoutRead($iPID) = Ncat: . >Exit code: 0 Time: 34.01 It's clear that the 2nd Run() $DOS2 actually does what it's supposed to do and writes the correct data to scan1.dta. If I comment this line out then no data appears. Also I now get a Command Prompt window opened. It takes approx. eight seconds for ProcessWait() to terminate. Edit: Tried "ShellExecute("data1.bat")" .. got a Command Prompt window for about eight seconds which closed without error but still no data saved. The batch file works perfectly from Command Prompt. So there seems to be a bug in AutoIt when running some Command Line programs? Edited June 7, 2017 by fopetesl The most powerful number in the Universe. Zero.
Developers Jos Posted June 7, 2017 Developers Posted June 7, 2017 6 hours ago, fopetesl said: It's clear that the 2nd Run() $DOS2 actually does what it's supposed to do and writes the correct data to scan1.dta. Then use that format and don't tell AutoIt3 to capture the STDOUT & STDERR since you want to pipe that into a file anyways, or do you see any issues with that? Jos SciTE4AutoIt3 Full installer Download page - Beta files Read before posting How to post scriptsource Forum etiquette Forum Rules Live for the present, Dream of the future, Learn from the past.
fopetesl Posted June 8, 2017 Author Posted June 8, 2017 (edited) 16 hours ago, Jos said: Then use that format and don't tell AutoIt3 to capture the STDOUT & STDERR since you want to pipe that into a file anyways, or do you see any issues with that? Jos I've no issue except the second (not $DOS2) call to capture data to scan2.dta always fails even if I call it twice $DOS2 = Run(@ComSpec & " /k " & "data1.bat") ; 2nd call works here Sleep(100) $DOS3 = Run(@ComSpec & " /k " & "data2.bat") Sleep(100) $DOS3 = Run(@ComSpec & " /k " & "data2.bat") ; 2nd call here doesn't Edited June 8, 2017 by fopetesl Missing text The most powerful number in the Universe. Zero.
Recommended Posts
Create an account or sign in to comment
You need to be a member in order to leave a comment
Create an account
Sign up for a new account in our community. It's easy!
Register a new accountSign in
Already have an account? Sign in here.
Sign In Now