Jump to content

AndreasNWWWWW

Active Members
  • Posts

    23
  • Joined

  • Last visited

Recent Profile Visitors

The recent visitors block is disabled and is not being shown to other users.

AndreasNWWWWW's Achievements

Seeker

Seeker (1/7)

0

Reputation

  1. Yes, and no. i want to delete duplicates, but i want the total time of those duplicates to be added to one value. ie. projectnumber 1 has 30 minutes recorded time projectnumber 1(duplicate) has 1 hour recorded time. i want to merge those two into one. projectnumber 1 = 1 hour 30 minutes. like this, only this merging happens in cell A and B
  2. but does that not just delete duplicate values? and not merge them togheter? ref the helptext
  3. Good evening! i was just curious, is it possible for autoit to consolidate equal items in one row, and sum the corresponding line in the other? i'm making a timetracker tool and with some help from Nine i have gotten it to work, however i'm trying to figure out how to consolidate data. like everything with projectnumber 2021-033-001 is merged to a total time instead of different lines so in the example below it would be three lines instead of 4,and line 2021-033-001 would count 2 seconds instead of two times one second
  4. And again you are a life saver! perhaps i'm getting this done this weekend after all, been sitting with it since thursday xD just need to figure out how to have only 8 buttons in a row, and then it goes 100 pixels over and reset the y axis for the next 8 two more times, so 24 buttons in total. And i'll publish the code, incase someone else wants something like this. For $i = 0 To UBound($aButton) - 1 $aButton[$i] = GUICtrlCreateButton("", 518, 70 + $i * 40, 80, 40) GUICtrlSetState(-1, $GUI_HIDE) Next
  5. i know i marked it as solved, but just had a little tiny question i have incorperated the script into the timer and looks like this now. but i have the same problem as before when trying to input the text into the input bar. it only takes one value for all buttons. this is the top of the script, so it creates the buttons and name them correctly according to the excelsheethowever when i push the corresponding button (last line) it only inputs one value and not the corresponding, i know i could make a case button1,2,3 up to 20, but is there a simpler way? like the $i way you posted earlier? last question, i promise For $i = 0 to Ubound($aResult) - 1 Local $aButton[20] For $i = 0 To UBound($aButton) - 1 $aButton[$i] = GUICtrlCreateButton("", 518, 70 + $i * 40, 80, 40) GUICtrlSetState(-1, $GUI_HIDE) Next GUISetState() For $i = 1 to Ubound($aResult) - 1 GUICtrlSetData($aButton[$i], $aresult[$i]) GUICtrlSetState($aButton[$i], $GUI_SHOW) Next While 1 $x = Int(Stopwatch() / 100) $nMsg = GUIGetMsg() Switch $nMsg ;Project button pressed Case $aButton[0] To $aButton[UBound($aButton) - 1] ConsoleWrite("Button " & $nMsg - $aButton[0] + 1 & " has been pressed" & @CRLF) GUICtrlSetData ( $Input1,$aresult[$i])
  6. That's noted! and sorry for posting 60 lines of code, with notes in a different language So now i have the buttons done, i can read the number of lines with $iLast. but there is something i am missing, if i change the $aresult[1,2,3,etc] i can read the different values, but it seems it wont go through the list. i have read on the wikki for arrays, but i can't make head or tails from it (https://www.autoitscript.com/wiki/Arrays) For $i = 0 to $iLast-1 GUICtrlSetData($aButton[$i], $aresult[0] ) GUICtrlSetState($aButton[$i], $GUI_SHOW) Next
  7. ;Trying to read ini file - Start Local Const $sFilePath = @ScriptDir & "\prosjekter.ini" $givename=IniRead($sFilePath, "Prosjektnummer","1","") ;tried using the ini file - Stops ;create buttons and name them $nMsg = GUIGetMsg() Local $aButton[20] For $i = 0 To UBound($aButton) - 1 $aButton[$i] = GUICtrlCreateButton("", 528, 60 + $i * 40, 200, 40) GUICtrlSetState(-1, $GUI_HIDE) Next GUISetState() For $i = 0 To 6 GUICtrlSetData($aButton[$i], "Number " & $givename & $i+1) GUICtrlSetState($aButton[$i], $GUI_SHOW) Next The section above is what i need to be able to read the excel sheet, atm i tried reading the ini file but without luck. The Excel file is simple, one title cell and then all projects are written down below. atm only 6. but that will increase in time (so it the buttons needs to be dynamic) the code i'm using to read the excel file is connected to a button as a function,and then writes it into an ini file(first thing i tried) -> in general: all i need is a way to read the excel sheet from A2 and below, create as many buttons as needed, then update the name on the buttons to the corresponding cell name, and have say 8 buttons per row like the image attached below. Func hentemappe() $programbane = IniRead("programbane.INI", "programbane", "adresse", "") Local $oExcel = _Excel_Open() Local $bReadOnly = False Local $bVisible = True Local $bsave = True Local $var = 1 Local $R = "D" & $var & ":" & "E" & $var ; **************************************************************************** ; Open an existing workbook and return its object identifier. ; ***************************************************************************** Local $sWorkbook = $programbane Local $inifilbane = @ScriptDir Local $oWorkbook = _Excel_BookOpen($oExcel, $sWorkbook, $bReadOnly, $bVisible) _Excel_BookClose($oExcel, $bsave) Local $aResult = _Excel_RangeRead($oWorkbook, Default, $oWorkbook.ActiveSheet.Usedrange.Columns("A"), 1) ;Local $aResult = _Excel_RangeRead($oWorkbook, Default, $oWorkbook.ActiveSheet.Usedrange.Columns("A:B"), 1) _ArrayDisplay($aResult) ;MsgBox(1,"",$aResult) For $i = 1 To UBound($aResult) - 1 ;ConsoleWrite($aResult[$i] & @CRLF) ;IniWriteSection("prosjekter.INI","Prosjektnummer",$aResult[$i]) IniWrite("prosjekter.INI", "Prosjektnummer", $aResult[$i],"") Next EndFunc ;==>hentemappe Nytt Microsoft Excel-regneark.xlsx
  8. but then i have a small question, how can i connect the excel array towards naming and the amount of buttons? i have tried using the Local $aResult = _Excel_RangeRead($oWorkbook, Default, $oWorkbook.ActiveSheet.Usedrange.Columns("A"), 1) and then use the $aResult to name them one by one, but without luck. #include <ButtonConstants.au3> #include <EditConstants.au3> #include <GUIConstantsEx.au3> #include <ListViewConstants.au3> #include <Excel.au3> #include <GuiListView.au3> #include <StaticConstants.au3> #include <WindowsConstants.au3> #include <GuiEdit.au3> #include <Constants.au3> #include <Misc.au3> Global $count = 0 #Region ### START Koda GUI section ### Form= $Form1_1 = GUICreate("Tidsrapport", 1273, 433, 192, 124) $Label1 = GUICtrlCreateLabel("Time Tracker", 142, 8, 120, 29) GUICtrlSetFont(-1, 15, 400, 0, "MS Sans Serif") $Label4 = GUICtrlCreateLabel("00:00:00", 72, 40, 244, 84) GUICtrlSetFont(-1, 50, 400, 0, "MS Sans Serif") GUICtrlSetColor(-1, 0x000000) $Label2 = GUICtrlCreateLabel("Prosjektnummer", 87, 90, 214, 29) GUICtrlSetFont(-1, 15, 400, 0, "MS Sans Serif") $Input1 = GUICtrlCreateInput("", 96, 130, 201, 21) $Label3 = GUICtrlCreateLabel("Prosjekter registrert", 120, 162, 130, 29) GUICtrlSetFont(-1, 15, 400, 0, "MS Sans Serif") $ListView1 = GUICtrlCreateListView("Prosjektnummer|Start tid|Slutt tid|Total tid", 8, 194, 385, 175) GUICtrlSendMsg(-1, $LVM_SETCOLUMNWIDTH, 0, 50) GUICtrlSendMsg(-1, $LVM_SETCOLUMNWIDTH, 1, 50) GUICtrlSendMsg(-1, $LVM_SETCOLUMNWIDTH, 2, 50) GUICtrlSendMsg(-1, $LVM_SETCOLUMNWIDTH, 3, 50) $ListView1_0 = GUICtrlCreateListViewItem("|hour:mintm", $ListView1) $Button1 = GUICtrlCreateButton("Start", 24, 376, 89, 41, $BS_NOTIFY) GUICtrlSetCursor(-1, 0) $Button2 = GUICtrlCreateButton("Eksporter til Excel", 152, 376, 89, 41, $BS_NOTIFY) GUICtrlSetCursor(-1, 0) $Button3 = GUICtrlCreateButton("Avbryt", 280, 376, 81, 41, $BS_NOTIFY) GUICtrlSetCursor(-1, 0) $SETTFIL = GUICtrlCreateButton("SETT FILBANE", 344, 40, 115, 25) $OPPDATERFIL = GUICtrlCreateButton("OPPDATER FILBANE", 344, 72, 115, 25) $FILBANE = GUICtrlCreateLabel("FILBANE:", 344, 24, 51, 17) ;$FILBANEVALGT = GUICtrlCreateLabel("sFileOpenDialog", 392, 16, 460, 25) GUISetState(@SW_SHOW) #EndRegion ### END Koda GUI section ### ;create buttons and name them $nMsg = GUIGetMsg() Local $aButton[20] For $i = 0 To UBound($aButton) - 1 $aButton[$i] = GUICtrlCreateButton("", 528, 60 + $i * 40, 200, 40) GUICtrlSetState(-1, $GUI_HIDE) Next GUISetState() For $i = 0 To 6 GUICtrlSetData($aButton[$i], "Number " & $i + 1) GUICtrlSetState($aButton[$i], $GUI_SHOW) Next ;startfil() While 1 $nMsg = GUIGetMsg() Switch $nMsg Case $GUI_EVENT_CLOSE Exit Case $SETTFIL mappevalg() Case $OPPDATERFIL hentemappe() ;Project button pressed Case $aButton[0] To $aButton[UBound($aButton) - 1] ConsoleWrite("Button " & $nMsg - $aButton[0] + 1 & " has been pressed" & @CRLF) EndSwitch WEnd Func hentemappe() $programbane = IniRead("programbane.INI", "programbane", "adresse", "") Local $oExcel = _Excel_Open() Local $bReadOnly = False Local $bVisible = True Local $bsave = True Local $var = 1 Local $R = "D" & $var & ":" & "E" & $var ; **************************************************************************** ; Open an existing workbook and return its object identifier. ; ***************************************************************************** Local $sWorkbook = $programbane Local $inifilbane = @ScriptDir Local $oWorkbook = _Excel_BookOpen($oExcel, $sWorkbook, $bReadOnly, $bVisible) _Excel_BookClose($oExcel, $bsave) Local $aResult = _Excel_RangeRead($oWorkbook, Default, $oWorkbook.ActiveSheet.Usedrange.Columns("A"), 1) ;Local $aResult = _Excel_RangeRead($oWorkbook, Default, $oWorkbook.ActiveSheet.Usedrange.Columns("A:B"), 1) _ArrayDisplay($aResult) ;MsgBox(1,"",$aResult) For $i = 1 To UBound($aResult) - 1 ;ConsoleWrite($aResult[$i] & @CRLF) ;IniWriteSection("prosjekter.INI","Prosjektnummer",$aResult[$i]) IniWrite("prosjekter.INI", "Prosjektnummer", $i, $aResult[$i]) Next EndFunc ;==>hentemappe Func mappevalg() ; Create a constant variable in Local scope of the message to display in FileOpenDialog. Local Const $sMessage = "Select a single file of any type." ; Display an open dialog to select a file. Local $sFileOpenDialog = FileOpenDialog($sMessage, @WindowsDir & "\", "All (*.*)", $FD_FILEMUSTEXIST) If @error Then ; Display the error message. MsgBox($MB_SYSTEMMODAL, "", "No file was selected.") ; Change the working directory (@WorkingDir) back to the location of the script directory as FileOpenDialog sets it to the last accessed folder. FileChangeDir(@ScriptDir) Else ; Change the working directory (@WorkingDir) back to the location of the script directory as FileOpenDialog sets it to the last accessed folder. FileChangeDir(@ScriptDir) ; Replace instances of "|" with @CRLF in the string returned by FileOpenDialog. $sFileOpenDialog = StringReplace($sFileOpenDialog, "|", @CRLF) ; Display the selected file. ;MsgBox($MB_SYSTEMMODAL, "", "You chose the following file:" & @CRLF & $sFileOpenDialog) IniWrite("programbane.INI", "programbane", "adresse", $sFileOpenDialog) Sleep(200) $FILBANEVALGT = GUICtrlCreateLabel($sFileOpenDialog, 392, 16, 460, 25) EndIf EndFunc ;==>mappevalg Func startfil() ;trigger innlastning av data til arket ved åpning Local $aButton[20] For $i = 0 To UBound($aButton) - 1 $aButton[$i] = GUICtrlCreateButton("", 10, 10 + $i * 25, 80, 20) GUICtrlSetState(-1, $GUI_HIDE) Next GUISetState() For $i = 0 To 6 GUICtrlSetData($aButton[$i], "Number " & $i + 1) GUICtrlSetState($aButton[$i], $GUI_SHOW) Next Local $nMsg While True $nMsg = GUIGetMsg() Switch $nMsg Case $GUI_EVENT_CLOSE ExitLoop Case $aButton[0] To $aButton[UBound($aButton) - 1] ConsoleWrite("Button " & $nMsg - $aButton[0] + 1 & " has been pressed" & @CRLF) EndSwitch WEnd EndFunc ;==>startfil
  9. cleaned up the script in previous post as suggested. 😃 and no, the Excel sheet is local only.
  10. i'm trying to use you approach to creating buttons. i'm just unsure if it's easier to just the data i pull from the excel sheet instead of going through the same step with an .INI file. now i'm trying to find a way to get the name of the buttons to correspond to the info in the Excel/ini file. Wish i had more knowledge with autoit than i do made like 3-4 simple programs like a year ago xD current code implemented your button solution. #include <ButtonConstants.au3> #include <EditConstants.au3> #include <GUIConstantsEx.au3> #include <ListViewConstants.au3> #include <Excel.au3> #include <GuiListView.au3> #include <StaticConstants.au3> #include <WindowsConstants.au3> #include <GuiEdit.au3> #include <Constants.au3> #include <Misc.au3> Global $count = 0 #Region ### START Koda GUI section ### Form= $Form1_1 = GUICreate("Tidsrapport", 1273, 433, 192, 124) $Label1 = GUICtrlCreateLabel("Time Tracker", 142, 8, 120, 29) GUICtrlSetFont(-1, 15, 400, 0, "MS Sans Serif") $Label4 = GUICtrlCreateLabel("00:00:00", 72, 40, 244, 84) GUICtrlSetFont(-1, 50, 400, 0, "MS Sans Serif") GUICtrlSetColor(-1, 0x000000) $Label2 = GUICtrlCreateLabel("Prosjektnummer", 87, 90, 214, 29) GUICtrlSetFont(-1, 15, 400, 0, "MS Sans Serif") $Input1 = GUICtrlCreateInput("", 96, 130, 201, 21) $Label3 = GUICtrlCreateLabel("Prosjekter registrert", 120, 162, 130, 29) GUICtrlSetFont(-1, 15, 400, 0, "MS Sans Serif") $ListView1 = GUICtrlCreateListView("Prosjektnummer|Start tid|Slutt tid|Total tid", 8, 194, 385, 175) GUICtrlSendMsg(-1, $LVM_SETCOLUMNWIDTH, 0, 50) GUICtrlSendMsg(-1, $LVM_SETCOLUMNWIDTH, 1, 50) GUICtrlSendMsg(-1, $LVM_SETCOLUMNWIDTH, 2, 50) GUICtrlSendMsg(-1, $LVM_SETCOLUMNWIDTH, 3, 50) $ListView1_0 = GUICtrlCreateListViewItem("|hour:mintm", $ListView1) $Button1 = GUICtrlCreateButton("Start", 24, 376, 89, 41, $BS_NOTIFY) GUICtrlSetCursor(-1, 0) $Button2 = GUICtrlCreateButton("Eksporter til Excel", 152, 376, 89, 41, $BS_NOTIFY) GUICtrlSetCursor(-1, 0) $Button3 = GUICtrlCreateButton("Avbryt", 280, 376, 81, 41, $BS_NOTIFY) GUICtrlSetCursor(-1, 0) $SETTFIL = GUICtrlCreateButton("SETT FILBANE", 344, 40, 115, 25) $OPPDATERFIL = GUICtrlCreateButton("OPPDATER FILBANE", 344, 72, 115, 25) $FILBANE = GUICtrlCreateLabel("FILBANE:", 344, 24, 51, 17) ;$FILBANEVALGT = GUICtrlCreateLabel("sFileOpenDialog", 392, 16, 460, 25) GUISetState(@SW_SHOW) #EndRegion ### END Koda GUI section ### ;setter mappestruktur fra INI.filen $nMsg = GUIGetMsg() Local $aButton[20] For $i = 0 To UBound($aButton) - 1 $aButton[$i] = GUICtrlCreateButton("", 528, 60 + $i * 40, 200, 40) GUICtrlSetState(-1, $GUI_HIDE) Next GUISetState() For $i = 0 To 6 GUICtrlSetData($aButton[$i], "Number " & $i + 1) GUICtrlSetState($aButton[$i], $GUI_SHOW) Next ;startfil() While 1 $nMsg = GUIGetMsg() Switch $nMsg Case $GUI_EVENT_CLOSE Exit Case $SETTFIL mappevalg() Case $OPPDATERFIL hentemappe() ;Project button pressed Case $aButton[0] To $aButton[UBound($aButton) - 1] ConsoleWrite("Button " & $nMsg - $aButton[0] + 1 & " has been pressed" & @CRLF) EndSwitch WEnd Func hentemappe() $programbane = IniRead("programbane.INI", "programbane", "adresse", "") Local $oExcel = _Excel_Open() Local $bReadOnly = False Local $bVisible = True Local $bsave = True Local $var = 1 Local $R = "D" & $var & ":" & "E" & $var ; **************************************************************************** ; Open an existing workbook and return its object identifier. ; ***************************************************************************** Local $sWorkbook = $programbane Local $inifilbane = @ScriptDir Local $oWorkbook = _Excel_BookOpen($oExcel, $sWorkbook, $bReadOnly, $bVisible) _Excel_BookClose($oExcel, $bsave) Local $aResult = _Excel_RangeRead($oWorkbook, Default, $oWorkbook.ActiveSheet.Usedrange.Columns("A"), 1) ;Local $aResult = _Excel_RangeRead($oWorkbook, Default, $oWorkbook.ActiveSheet.Usedrange.Columns("A:B"), 1) _ArrayDisplay($aResult) ;MsgBox(1,"",$aResult) For $i = 1 To UBound($aResult) - 1 ;ConsoleWrite($aResult[$i] & @CRLF) ;IniWriteSection("prosjekter.INI","Prosjektnummer",$aResult[$i]) IniWrite("prosjekter.INI", "Prosjektnummer", $aResult[$i], "") Next EndFunc ;==>hentemappe Func mappevalg() ; Create a constant variable in Local scope of the message to display in FileOpenDialog. Local Const $sMessage = "Select a single file of any type." ; Display an open dialog to select a file. Local $sFileOpenDialog = FileOpenDialog($sMessage, @WindowsDir & "\", "All (*.*)", $FD_FILEMUSTEXIST) If @error Then ; Display the error message. MsgBox($MB_SYSTEMMODAL, "", "No file was selected.") ; Change the working directory (@WorkingDir) back to the location of the script directory as FileOpenDialog sets it to the last accessed folder. FileChangeDir(@ScriptDir) Else ; Change the working directory (@WorkingDir) back to the location of the script directory as FileOpenDialog sets it to the last accessed folder. FileChangeDir(@ScriptDir) ; Replace instances of "|" with @CRLF in the string returned by FileOpenDialog. $sFileOpenDialog = StringReplace($sFileOpenDialog, "|", @CRLF) ; Display the selected file. ;MsgBox($MB_SYSTEMMODAL, "", "You chose the following file:" & @CRLF & $sFileOpenDialog) IniWrite("programbane.INI", "programbane", "adresse", $sFileOpenDialog) Sleep(200) $FILBANEVALGT = GUICtrlCreateLabel($sFileOpenDialog, 392, 16, 460, 25) EndIf EndFunc ;==>mappevalg Func startfil() ;trigger innlastning av data til arket ved åpning Local $aButton[20] For $i = 0 To UBound($aButton) - 1 $aButton[$i] = GUICtrlCreateButton("", 10, 10 + $i * 25, 80, 20) GUICtrlSetState(-1, $GUI_HIDE) Next GUISetState() For $i = 0 To 6 GUICtrlSetData($aButton[$i], "Number " & $i + 1) GUICtrlSetState($aButton[$i], $GUI_SHOW) Next Local $nMsg While True $nMsg = GUIGetMsg() Switch $nMsg Case $GUI_EVENT_CLOSE ExitLoop Case $aButton[0] To $aButton[UBound($aButton) - 1] ConsoleWrite("Button " & $nMsg - $aButton[0] + 1 & " has been pressed" & @CRLF) EndSwitch WEnd EndFunc ;==>startfil
  11. Now that i have solved my initial problem, is there a way to use GUICtrlSetData based on how many arrays that is generated? for example here i have 6 projects,a so i need it to update names on 6 buttons, all buttons are without text so white until something is written, planing on having 10-20 buttons in total. my current code is looking like this, is there a way to have it update the buttons as needed? ie $button + number, and have it to connect the result from the ini file ini-file #include <ButtonConstants.au3> #include <EditConstants.au3> #include <GUIConstantsEx.au3> #include <ListViewConstants.au3> #include <Excel.au3> #include <GuiListView.au3> #include <StaticConstants.au3> #include <WindowsConstants.au3> #include <GuiEdit.au3> #include <Constants.au3> #include <Misc.au3> Global $count = 0 #Region ### START Koda GUI section ### Form= $Form1_1 = GUICreate("Tidsrapport", 1273, 433, 192, 124) $Label1 = GUICtrlCreateLabel("Time Tracker", 142, 8, 120, 29) GUICtrlSetFont(-1, 15, 400, 0, "MS Sans Serif") $Label4 = GUICtrlCreateLabel("00:00:00", 72, 40, 244, 84) GUICtrlSetFont(-1, 50, 400, 0, "MS Sans Serif") GUICtrlSetColor(-1, 0x000000) $Label2 = GUICtrlCreateLabel("Prosjektnummer", 87, 90, 214, 29) GUICtrlSetFont(-1, 15, 400, 0, "MS Sans Serif") $Input1 = GUICtrlCreateInput("", 96, 130, 201, 21) $Label3 = GUICtrlCreateLabel("Prosjekter registrert", 120, 162, 130, 29) GUICtrlSetFont(-1, 15, 400, 0, "MS Sans Serif") $ListView1 = GUICtrlCreateListView("Prosjektnummer|Start tid|Slutt tid|Total tid", 8, 194, 385, 175) GUICtrlSendMsg(-1, $LVM_SETCOLUMNWIDTH, 0, 50) GUICtrlSendMsg(-1, $LVM_SETCOLUMNWIDTH, 1, 50) GUICtrlSendMsg(-1, $LVM_SETCOLUMNWIDTH, 2, 50) GUICtrlSendMsg(-1, $LVM_SETCOLUMNWIDTH, 3, 50) $ListView1_0 = GUICtrlCreateListViewItem("|hour:mintm", $ListView1) $Button1 = GUICtrlCreateButton("Start", 24, 376, 89, 41, $BS_NOTIFY) GUICtrlSetCursor (-1, 0) $Button2 = GUICtrlCreateButton("Eksporter til Excel", 152, 376, 89, 41, $BS_NOTIFY) GUICtrlSetCursor (-1, 0) $Button3 = GUICtrlCreateButton("Avbryt", 280, 376, 81, 41, $BS_NOTIFY) GUICtrlSetCursor (-1, 0) $SETTFIL = GUICtrlCreateButton("SETT FILBANE", 344, 40, 115, 25) $OPPDATERFIL = GUICtrlCreateButton("OPPDATER FILBANE", 344, 72, 115, 25) $FILBANE = GUICtrlCreateLabel("FILBANE:", 344, 24, 51, 17) $Button4 = GUICtrlCreateButton("Prosjekt-1", 528, 152, 171, 25) $Button5 = GUICtrlCreateButton("", 528, 184, 171, 25) ;$FILBANEVALGT = GUICtrlCreateLabel("sFileOpenDialog", 392, 16, 460, 25) $Button6 = GUICtrlCreateButton("", 528, 216, 171, 25) $Button7 = GUICtrlCreateButton("", 528, 248, 171, 25) $Button8 = GUICtrlCreateButton("", 528, 280, 171, 25) $Button9 = GUICtrlCreateButton("", 528, 312, 171, 25) $Button10 = GUICtrlCreateButton("", 528, 344, 171, 25) GUISetState(@SW_SHOW) #EndRegion ### END Koda GUI section ### $nMsg = GUIGetMsg() While 1 $nMsg = GUIGetMsg() Switch $nMsg Case $GUI_EVENT_CLOSE Exit Case $SETTFIL mappevalg() Case $OPPDATERFIL hentemappe() EndSwitch WEnd Func hentemappe() $programbane =IniRead ( "programbane.INI", "programbane", "adresse", "" ) Local $oExcel = _Excel_Open() Local $bReadOnly = False Local $bVisible = True Local $var = 1 Local $R = "D" & $var & ":" & "E" & $var ; **************************************************************************** ; Open an existing workbook and return its object identifier. ; ***************************************************************************** Local $sWorkbook = $programbane local $inifilbane=@ScriptDir Local $oWorkbook = _Excel_BookOpen($oExcel, $sWorkbook, $bReadOnly, $bVisible) Local $aResult = _Excel_RangeRead($oWorkbook, Default, $oWorkbook.ActiveSheet.Usedrange.Columns("A"),1) ;Local $aResult = _Excel_RangeRead($oWorkbook, Default, $oWorkbook.ActiveSheet.Usedrange.Columns("A:B"), 1) _ArrayDisplay($aResult) ;MsgBox(1,"",$aResult) For $i = 1 to UBound($aResult) - 1 ;ConsoleWrite($aResult[$i] & @CRLF) ;IniWriteSection("prosjekter.INI","Prosjektnummer",$aResult[$i]) IniWrite("prosjekter.INI","Prosjektnummer",$aResult[$i],"") ;lager nye prosjektmapper GUICtrlSetData($Button4, $aResult[$i]) GUICtrlSetData($Button5, $aResult[$i]) GUICtrlSetData($Button6, $aResult[$i]) GUICtrlSetData($Button7, $aResult[$i]) GUICtrlSetData($Button8, $aResult[$i]) GUICtrlSetData($Button9, $aResult[$i]) GUICtrlSetData($Button10, $aResult[$i]) Next EndFunc Func mappevalg() ; Create a constant variable in Local scope of the message to display in FileOpenDialog. Local Const $sMessage = "Select a single file of any type." ; Display an open dialog to select a file. Local $sFileOpenDialog = FileOpenDialog($sMessage, @WindowsDir & "\", "All (*.*)", $FD_FILEMUSTEXIST) If @error Then ; Display the error message. MsgBox($MB_SYSTEMMODAL, "", "No file was selected.") ; Change the working directory (@WorkingDir) back to the location of the script directory as FileOpenDialog sets it to the last accessed folder. FileChangeDir(@ScriptDir) Else ; Change the working directory (@WorkingDir) back to the location of the script directory as FileOpenDialog sets it to the last accessed folder. FileChangeDir(@ScriptDir) ; Replace instances of "|" with @CRLF in the string returned by FileOpenDialog. $sFileOpenDialog = StringReplace($sFileOpenDialog, "|", @CRLF) ; Display the selected file. ;MsgBox($MB_SYSTEMMODAL, "", "You chose the following file:" & @CRLF & $sFileOpenDialog) IniWrite ( "programbane.INI", "programbane", "adresse",$sFileOpenDialog ) sleep(200) $FILBANEVALGT = GUICtrlCreateLabel($sFileOpenDialog, 392, 16, 460, 25) EndIf EndFunc ;==>Example image:
  12. The backstory of my project is that i'm a newly educated construction engineer, and at my workplace we keep hourtracking in an excel spreadsheet. and i'm looking for a way to make this a little bit easier. i have reversed engineered a script i found here https://www.autoitscript.com/forum/topic/187139-time-tracker/ to fit my need. the layout it has atm is looking like this Image(A), however i am trying to make it like Image(B) where the button name(s) is populated with the info from the Excelsheet cell value. ie project 1 button has the name from excel A2 = 2022-001-001 and then i'm planing on having it so that once that button is pushed the timer starts tracking on that project number. and so at the end of the day when i save the file it says the time used on each projectnumber. so when a new project starts i just add it to the excel sheet, and then next time i open the timetracker a new button is populated ready to track time used on that project. and since i'm rather new to Autoit, just used it every now and then, .INI writing is the only way i know of. i am able to write it into the ini file, however i can only read the value with this script if i add a = sign after the name in the ini file. Local Const $sFilePath = @ScriptDir & "\prosjekter.ini" ; Read the INI section labelled 'General'. This will return a 2 dimensional array. Local $aArray = IniReadSection($sFilePath, "Prosjektnummer") ; Check if an error occurred. If not @error Then ; Enumerate through the array displaying the keys and their respective values. For $i = 1 To $aArray[0][0]+2 MsgBox($MB_SYSTEMMODAL, "", "Key: " & $aArray[$i][0]) Next EndIf and since the first script posted don't go through all if i add a = i'm stuck update: managed to get it to write the = sign i need to be able to read the values, with iniwrite instead of section IniWrite("prosjekter.INI","Prosjektnummer",$aResult[$i],"") IniWrite("prosjekter.INI","Prosjektnummer",$aResult[$i],"") Image(A) Image(B)
  13. Hello, i where wondering if anyone could help me. i'm trying to read the excel values into a ini file to later read them and create label buttons from it. first part : reading excel goes well, however as soon as i have "=" or any equal signs in there it only takes the first value and writes it into the INI file. like it stops after one go. and not until all values has been written. Func hentemappe() $programbane =IniRead ( "programbane.INI", "programbane", "adresse", "" ) Local $oExcel = _Excel_Open() Local $bReadOnly = False Local $bVisible = True Local $var = 1 Local $R = "D" & $var & ":" & "E" & $var ; **************************************************************************** ; Open an existing workbook and return its object identifier. ; ***************************************************************************** Local $sWorkbook = $programbane local $inifilbane=@ScriptDir Local $oWorkbook = _Excel_BookOpen($oExcel, $sWorkbook, $bReadOnly, $bVisible) Local $aResult = _Excel_RangeRead($oWorkbook, Default, $oWorkbook.ActiveSheet.Usedrange.Columns("A"), 1) _ArrayDisplay($aResult) ;MsgBox(1,"",$aResult) For $i = 1 To ($aResult) ConsoleWrite($aResult[$i] & @CRLF) IniWriteSection("prosjekter.INI","Prosjektnummer",$aResult[$i] & "=" ) Next EndFunc second part is the reading section of the file based on the example script. however that won't show any values unless there is a = sign after the values in the ini.file. Func Example() ; Create a constant variable in Local scope of the filepath that will be read/written to. $x=0 Local Const $sFilePath = @ScriptDir & "\prosjekter.ini" ; Read the INI section labelled 'General'. This will return a 2 dimensional array. Local $aArray = IniReadSection($sFilePath, "Prosjektnummer") ; Check if an error occurred. If not @error Then ; Enumerate through the array displaying the keys and their respective values. For $i = 1 To $aArray[0][0]+2 MsgBox($MB_SYSTEMMODAL, "", "Key: " & $aArray[$i][0]) Next EndIf ; Delete the INI file. EndFunc ;==>Example what am i missing here? is there a way to get the reading of the ini section to only look for one value in the array? and don't need the = sign?
  14. sure does [payment] 14=50013=GREY12=50011=60010=6009=6008=7007=7005=6003=6002=8001=70015=GREY4=GREY [invoiced]
×
×
  • Create New...