Wellwellwell Posted March 15, 2021 Share Posted March 15, 2021 Hi. My goal is to grab input from User, Then it will open an excel sheet to look into column H, do a _Excel_RangeFind to match the input from user and return the Row number. Local $Excel_1 = _Excel_Open() If @error Then Exit MsgBox($MB_SYSTEMMODAL, "Excel UDF: _Excel_BookOpen Example", "Error creating the Excel application object." & @CRLF & "@error = " & @error & ", @extended = " & @extended) $sWorkbook = @ScriptDir & "\Test.xlsx" $oWorkbook = _Excel_BookOpen($Excel_1, $sWorkbook) If @error Then Exit MsgBox($MB_SYSTEMMODAL, "Excel UDF: _Excel_BookOpen Example 1", "Error opening '" & $sWorkbook & "'." & @CRLF & "@error = " & @error & ", @extended = " & @extended) ;get last row Local $LastRow = $oWorkbook.ActiveSheet.Range("H1").SpecialCells($xlCellTypeLastCell).Row Local $sSearchrange = "H1:H" & $LastRow ;Search for input serial number Local $rangeselect = $oWorkbook.Application.ActiveSheet.Columns("H").Select Local $rRowaddress = _Excel_RangeFind($oWorkbook, $input, $sSearchrange, $xlValues, $xlWhole) If @error Then Exit MsgBox($MB_SYSTEMMODAL, "Excel UDF: _Excel_RangeFind Example 3", "Error searching the range." & @CRLF & "@error = " & @error & ", @extended = " & @extended) Let say my excel file have below number: Row 1 100 Row 2 23 Row 3 45 Row 4 69 Row 5 200 Row 6 40 Row 7 45 Row 8 66 If the input are "45", Currently my $rRowaddress always return Row3 because it search from Top to bottom. How to set _Excel_RangeFind search from Bottom to Top, i would like Excel_RangeFind return Row7 value Thanks! Link to comment Share on other sites More sharing options...
Nine Posted March 15, 2021 Share Posted March 15, 2021 One way : #include <Excel.au3> Local $oExcel = _Excel_Open() Local $oWorkbook = _Excel_BookOpen($oExcel, @ScriptDir & "\Test.xls") ;get last row Local $LastRow = $oWorkbook.ActiveSheet.Range("H1").SpecialCells($xlCellTypeLastCell).Row Local $sSearchrange = "H1:H" & $LastRow Local $aResult = _Excel_RangeRead($oWorkbook, Default, $sSearchrange) Local $aList = _ArrayFindAll($aResult, 45) MsgBox ($MB_SYSTEMMODAL, "Last found in", $aList[UBound($aList)-1]+1) Wellwellwell 1 “They did not know it was impossible, so they did it” ― Mark Twain Spoiler Block all input without UAC Save/Retrieve Images to/from Text Monitor Management (VCP commands) Tool to search in text (au3) files Date Range Picker Virtual Desktop Manager Sudoku Game 2020 Overlapped Named Pipe IPC HotString 2.0 - Hot keys with string x64 Bitwise Operations Multi-keyboards HotKeySet Recursive Array Display Fast and simple WCD IPC Multiple Folders Selector Printer Manager GIF Animation (cached) Screen Scraping Multi-Threading Made Easy Link to comment Share on other sites More sharing options...
water Posted March 15, 2021 Share Posted March 15, 2021 _Excel_RangeFind returns a 2D array holding all found cells (from top to bottom) meeting the search criteria. Just process the returned array from bottom to top Wellwellwell 1 My UDFs and Tutorials: Spoiler UDFs: Active Directory (NEW 2024-07-28 - Version 1.6.3.0) - Download - General Help & Support - Example Scripts - Wiki ExcelChart (2017-07-21 - Version 0.4.0.1) - Download - General Help & Support - Example Scripts OutlookEX (2021-11-16 - Version 1.7.0.0) - Download - General Help & Support - Example Scripts - Wiki OutlookEX_GUI (2021-04-13 - Version 1.4.0.0) - Download Outlook Tools (2019-07-22 - Version 0.6.0.0) - Download - General Help & Support - Wiki PowerPoint (2021-08-31 - Version 1.5.0.0) - Download - General Help & Support - Example Scripts - Wiki Task Scheduler (2022-07-28 - Version 1.6.0.1) - Download - General Help & Support - Wiki Standard UDFs: Excel - Example Scripts - Wiki Word - Wiki Tutorials: ADO - Wiki WebDriver - Wiki Link to comment Share on other sites More sharing options...
Wellwellwell Posted March 16, 2021 Author Share Posted March 16, 2021 Hi Nine and water, Thanks for the suggestion. I have tried Nine codes and it works. It make sense to get list of array then search from bottom to top. Thanks! Link to comment Share on other sites More sharing options...
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