Jump to content
Hoth2001

Loop Through 2d Array Problem

Recommended Posts

Hoth2001

I am writing a program to automate another program

I created a simple array (image of array attached) that I'm trying to loop through and call elements from the array into my code

#RequireAdmin

#include<file.au3>

;~ _ArrayDisplay($aArray)
local $aArray
_FileReadToArray("C:\Users\User\Desktop\Simple.csv" , $aArray, 0, ",")

Run("C:\Users\User\Desktop\Ingabo HP computer\Desktop\Techsignal\CPM\CelestialPriceMoves.UI.exe")
WinWait('Celestial Price Moves    (Current Version: 1.3.14, Release Date: 03/08/2014)')
WinActivate("Celestial Price Moves  (Current Version 1.3.14, Release Date: 03/08/2014)")
Sleep(4000)

AutoItSetOption('MouseCoordMode' , 0)
AutoItSetOption('SendKeyDelay', 10)

For $i = 1 To UBound($aArray) - 1
    For $j = 0 To UBound($aArray, 2) - 1

;SET TRANSIT BODY (PLANET)
Send("{TAB}")
Send("{TAB}")
Send("{TAB}")
Send("{TAB}")
Send("{TAB}")
Send("{TAB}")
Send("{TAB}")
Send("{TAB}")
Send("{TAB}")
Send("{TAB}")
Send("{TAB}")
Send("{TAB}")
Send("{TAB}")
Send("{TAB}")
Send("{TAB}")
Send("{TAB}")
Send("{TAB}")
Send("{TAB}")
Send("{TAB}")
Send("{TAB}")
Send("{TAB}")
Send("{TAB}")
Send("{TAB}")
Send("{TAB}")
Send("{TAB}")
Send("{TAB}")
Sleep(300)
Send("{DELETE}")
Send($aArray[$i][$j])
Sleep(300)

;~ ;PLANET RATE OF CHANGE MAXIMUM
MouseClick('primary', 320,156, 1, 0)
Sleep(300)
Send("{DELETE}")
Send("{DELETE}")
Send("{DELETE}")
sleep(200)
Send($aArray[$i][$j])
;~ Send("{TAB}")
sleep(500)

    Next
Next

I am trying to in the code

FIRST:  send tab 26 times  and then Send the first element of the array

SECOND: Click at another location in the program window and Send the 2nd element of the array.

 

When I execute the program the script seems to 

FIRST: send tab 26 times and then Send the first element of the array

SECOND: tab 26 times AGAIN!!!

THIRD: Click at another location in the program window and Send the 2nd element of the array.

 

What is wrong with my code that makes the loop do the 26 tabs two times?!?!?!?

SimpleArray.png

Share this post


Link to post
Share on other sites
iamtheky
For every row

   For each column

       tab 26x

      send array[$i[$j]

      mouseclick

      send 3 deletes

     send the same shit again because you havent incremented $j yet

Next

    Increment $j and do all of the above for every column on row $i

Next

    Now onto the next row, where we do it all again.

that is what your code does

 

Also, this line in the helpfile for 'send' could be used to clean up all those tabs

Quote

Send("{S 30}") ;Sends 30 'S' characters

 

Edited by iamtheky

,-. .--. ________ .-. .-. ,---. ,-. .-. .-. .-.
|(| / /\ \ |\ /| |__ __||| | | || .-' | |/ / \ \_/ )/
(_) / /__\ \ |(\ / | )| | | `-' | | `-. | | / __ \ (_)
| | | __ | (_)\/ | (_) | | .-. | | .-' | | \ |__| ) (
| | | | |)| | \ / | | | | | |)| | `--. | |) \ | |
`-' |_| (_) | |\/| | `-' /( (_)/( __.' |((_)-' /(_|
'-' '-' (__) (__) (_) (__)

Share this post


Link to post
Share on other sites
careca

Can you attach a bogus csv for test? Also,

Send("{TAB 26}")

 


Spoiler

Paster - Main function is to paste text, but has more functions.

OpenW - Open With... alternative, Open any file with any application, set it's icon, set application as default.

Renamer - Rename files and folders, remove portions of text from the filename etc.

BeatsPlayer - Music player.

Params Tool - Right click an exe to see it's parameters or execute them.

Regedit Control - Registry browsing history, quickly jump into any saved key.

Time4Shutdown - Write the time for shutdown in minutes.

Power Profiles Tool - Set a profile as active, delete, duplicate, export and import.

Firefox Profile Backup - Backup/restore previously saved profile.

Finished Task Shutdown - Shuts down pc when specified window/Wndl/process closes.

NetworkSpeedShutdown - Shuts down pc if download speed goes under "X" Kb/s.

IUIAutomation - Topic with framework and examples

Au3Record.exe

Share this post


Link to post
Share on other sites
Hoth2001
7 minutes ago, iamtheky said:

For every row

   For each column

       tab 26x

      send array[$i[$j]

      mouseclick

      send 3 deletes

     send the same shit again because you havent incremented $j yet

Next

    Do all of the above for every column on row $i

Next

    Now onto the next row, where we do it all again.

Ok thanks IamSky.

So....my syntax is clearly wrong.  

I'm now confused as to what the correct syntax would be.

The goal I am trying to achieve is call on elements of the array at various points throughout my code.

 

I thought a nested for loop would achieve that aim...but I guess not???

Could you point me in the right direction??

5 minutes ago, careca said:

Can you attach a bogus csv for test? Also,

Send("{TAB 26}")

 

Careca I've attached the csv I've been using

 

Simple.csv

Edited by Hoth2001

Share this post


Link to post
Share on other sites
careca

Do you only want the "TAB x26 times" once?

The loop works well for repeated tasks, for example send a tab 26 times for every row in the column.

What do you need it to do? Im a bit confused sorry.

What do you mean " call on elements of the array at various points throughout my code. "

something like call a specific item in a specific row and column?

Edited by careca

Spoiler

Paster - Main function is to paste text, but has more functions.

OpenW - Open With... alternative, Open any file with any application, set it's icon, set application as default.

Renamer - Rename files and folders, remove portions of text from the filename etc.

BeatsPlayer - Music player.

Params Tool - Right click an exe to see it's parameters or execute them.

Regedit Control - Registry browsing history, quickly jump into any saved key.

Time4Shutdown - Write the time for shutdown in minutes.

Power Profiles Tool - Set a profile as active, delete, duplicate, export and import.

Firefox Profile Backup - Backup/restore previously saved profile.

Finished Task Shutdown - Shuts down pc when specified window/Wndl/process closes.

NetworkSpeedShutdown - Shuts down pc if download speed goes under "X" Kb/s.

IUIAutomation - Topic with framework and examples

Au3Record.exe

Share this post


Link to post
Share on other sites
Hoth2001

Ok...sorry if I have confused you.   

What I am trying to do is insert consecutive elements from my array at various points throughout my code.

 

For example:

I want to Tab 26 times

 Send $aArray [1][0]

Click Mouse

Send Delete 3 times

Send $aArray Element [1][1]

Click Mouse somewhere else

Send Tab 2 times

Send $aArray Element [2][0]

click mouse somewhere else

Send Delete 1 time

Send $aArray Element [2][1]

Share this post


Link to post
Share on other sites
careca

There's no cyclic action, I guess i would do this in a different way.

Example:

#include <Array.au3>
#include<file.au3>

local $aArray
_FileReadToArray("C:\Users\careca\Desktop\Simple.csv" , $aArray, 0, ",")
;_ArrayDisplay($aArray)

AutoItSetOption('MouseCoordMode' , 0)
AutoItSetOption('SendKeyDelay', 10)
;=============================================================================
For $i = 1 To UBound($aArray) - 1
    For $j = 0 To UBound($aArray, 2) - 1
        MsgBox(64, '', $aArray[$i][$j])
        If $aArray[$i][$j] = 'abc' Then
            abc()
        ElseIf $aArray[$i][$j] = 'Me' Then
            Me()
        EndIf
    Next
Next
;=============================================================================
Func abc()
    ConsoleWrite('abc - do this, do that - '&@MSEC&@CRLF)
    Beep(500, 500)
EndFunc
;=============================================================================
Func Me()
    ConsoleWrite('Me - do this, do that - '&@MSEC&@CRLF)
    Beep(800, 500)
EndFunc
;=============================================================================

This way you can set specific actions to specific items. Just have to place those in the according function.

BTW i added items to the csv, doesn't matter, i think you get the idea.


Spoiler

Paster - Main function is to paste text, but has more functions.

OpenW - Open With... alternative, Open any file with any application, set it's icon, set application as default.

Renamer - Rename files and folders, remove portions of text from the filename etc.

BeatsPlayer - Music player.

Params Tool - Right click an exe to see it's parameters or execute them.

Regedit Control - Registry browsing history, quickly jump into any saved key.

Time4Shutdown - Write the time for shutdown in minutes.

Power Profiles Tool - Set a profile as active, delete, duplicate, export and import.

Firefox Profile Backup - Backup/restore previously saved profile.

Finished Task Shutdown - Shuts down pc when specified window/Wndl/process closes.

NetworkSpeedShutdown - Shuts down pc if download speed goes under "X" Kb/s.

IUIAutomation - Topic with framework and examples

Au3Record.exe

Share this post


Link to post
Share on other sites

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 account

Sign in

Already have an account? Sign in here.

Sign In Now

  • Similar Content

    • DynamicRookie
      By DynamicRookie
      Hey there!
       
      Is there a way to detect movement only for 1 specific window?

      HWnd is not really working, it still detects movement in all the windows within the region

      This is my script:
       
      ;Checksum actual HotKeySet("{f2}", 'exit_') MsgBox(0, '', '0') Beep(500, 2000) $Hwnd = WinActive('') while 1 $Checksum = PixelChecksum(211, 650, 1094, 914, 1, $Hwnd) If PixelChecksum(211, 650, 1094, 914, 1, $Hwnd) <> $Checksum Then For $i = 1 To 100 Beep(1000, 50) Next MsgBox(0, '', 'New message!', 1) EndIf WEnd Func exit_() Beep(500, 1000) Exit 0 EndFunc I just want to check whenever a message comes because the app i use doesn't give notifications properly.

      Any help is really appreciated!
    • PramodR
      By PramodR
      Can you please see whats wrong im doing in the below code? i can read few registry entry but not all for eg, i am able to get value of "Shell" Key from the registry path  but not AutoAdminLogon which has the value of "1", is there any change i have to do to read numeric values?
       Global  $shello = RegRead ("HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows NT\CurrentVersion\Winlogon","Shell" )
       ConsoleWrite("This is Hello"& $shello)
      above command returns proper value , but same command with AutoAdminLogon returns null as shown in below ? infact registry has the value of 1.
       Global  $shello = RegRead ("HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows NT\CurrentVersion\Winlogon","AutoAdminLogon" )
       ConsoleWrite("This is Hello"& $shello)
    • Eminence
      By Eminence
      Hello,
      I've been searching on how to select the first row in my database which includes a time column based on the latest start_time date for today's date.
      This is my current code:
      Local $iCurrentDate = _Now() Local $sqlHandle = _dbOpen($sDbPath) Local $aResult, $iRows, $iCols _SQLite_GetTable2d($sqlHandle, "SELECT start_time FROM " & $srawDb & " ORDER BY datetime(start_time) DESC LIMIT 1", $aResult, $iRows, $iCols) _ArrayDisplay($aResult) _dbClose($sDbpath) What it does is it gets the first row entry in the database however it does not select the latest start_time entry in the database, it always select the first row. I've tried changing DESC to ASC to see if that will do it but the issue still remains. Any thoughts on this? Thanks in advance.
       
      *EDIT
      The date format in the database is by MM/DD/YYYY HH:MM:SS.
    • Trisha
      By Trisha
      Hello,
      I Have clicked on save as option to save a file, while doing that I need to rename a file appending with sysdate. I have searched in google find the below one line of code:
      FileMove("C:\somefile.txt", "C:\somefile1.txt"), When I am trying to append with sysdate. It is not happening. Please help me out  with the small issue.
    • TrashBoat
      By TrashBoat
      hey i would like to know if its possible to take a string like this
      $string = "onethousandninehundredeightyfive" and convert it into:
      $string = "one thousand nine hundred eighty five" i have something going on here but its no use
      $string = "onethousandninehundredeightyfive" Global $array[9] = ['one', 'two', 'three', 'four', 'five', 'six', 'seven', 'eight', 'nine'] Global $array1[19] = ['onethousand', 'twothousand', 'threethousand', 'fourthousand', 'fivethousand', 'sixthousand', 'seventhousand', 'eightthousand', 'ninethousand','tenthousand','hundred', 'twohundred', 'threehundred', 'fourhundred', 'fivehundred', 'sixhundred', 'sevenhundred', 'eighthundred', 'ninehundred'] MsgBox(0, 0, AddSpaces($string)) Func AddSpaces($string) Local $finalStr $length = StringLen($string) For $x = 0 To $length Local $trim = StringTrimRight($string, $x) For $h = 0 To 18 If $trim = $array1[$h] Then $finalStr = $finalStr & " " & $trim $string = StringTrimLeft($string, $h) $length = StringLen($string) EndIf Next For $z = 0 To 8 If $trim = $array[$z] Then $finalStr = $finalStr & " " & $trim $string = StringTrimLeft($string, $z) $length = StringLen($string) EndIf Next Next Return $finalStr EndFunc ;==>AddSpaces  
×

Important Information

We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue.