kctvt

How to know max number in Excel

7 posts in this topic

Hi there, i'm looking for a script to take max number of a column in Excel.

 

Ex :  Column C , i have : 

12

13

22

123

154

....

.....

.....

134534

(About 134600 rows)


So, How to know which is the max number in Column C.

I have this code, but it take me a lot of time >"< 

So... please help me a faster code.

 

$x = 3

$CloseCheck1 = _Excel_RangeRead($oWorkbook, Default, "C"&$x+1)
$CloseCheck2 = _Excel_RangeRead($oWorkbook, Default, "C"&$x+2)
$CloseCheck3 = _Excel_RangeRead($oWorkbook, Default, "C"&$x+3)
$CloseCheck4 = _Excel_RangeRead($oWorkbook, Default, "C"&$x+4)
$CloseCheck5 = _Excel_RangeRead($oWorkbook, Default, "C"&$x+5)
$CloseCheck6 = _Excel_RangeRead($oWorkbook, Default, "C"&$x+6)
$CloseCheck7 = _Excel_RangeRead($oWorkbook, Default, "C"&$x+7)
$CloseCheck8 = _Excel_RangeRead($oWorkbook, Default, "C"&$x+8)
$CloseCheck9 = _Excel_RangeRead($oWorkbook, Default, "C"&$x+9)
$CloseCheck10 = _Excel_RangeRead($oWorkbook, Default, "C"&$x+10)

Local $aArray = StringSplit($CloseCheck1&","&$CloseCheck2&","&$CloseCheck3&","&$CloseCheck4&","&$CloseCheck5&","&$CloseCheck6&","&$CloseCheck7&","&$CloseCheck8&","&$CloseCheck9&","&$CloseCheck10,",")
$DMAX = _ArrayMax($aArray, 1, 1)
$DMIN = _ArrayMin($aArray, 1, 1)

$n = 11
While 1
$CloseCheckn = _Excel_RangeRead($oWorkbook, Default, "C"&$x+n)

If $CloseCheckn > $DMAX Then
Global $DMAX = $CloseCheckn
EndIf

If $CloseCheckn < $DMIN Then
Global $MIN = $CloseCheckn
EndIf

If $CloseCheckn = "" Then
   ExitLoop
EndIf

$n = $n + 1
WEnd

_Excel_RangeWrite($oWorkbook, $oWorkbook.Activesheet, $DMAX, "P1")
_Excel_RangeWrite($oWorkbook, $oWorkbook.Activesheet, $DMIN, "P2")

 

 

Thanks :) 

 

 

 

 

Share this post


Link to post
Share on other sites



7 minutes ago, Anoop said:

Take the data in an array using 

_Excel_RangeRead

and use 

_ArrayMax

to find the highest value.

 

 

Thank Anoop, I try, but it dont work. This is my code : 

Global $oAppl = _Excel_Open()
Global $sWorkbook1 = @ScriptDir & "\Test.xls"
Global $oWorkbook1 = _Excel_BookOpen($oAppl, $sWorkbook1, Default, Default, True)

$aResult = _Excel_RangeRead($oWorkbook1, 2, "F1:F39", 1)
$max = _ArrayMax($aResult, 0, 1)
MsgBox($MB_SYSTEMMODAL, "","$max  is : " & $max)

 

 

 

 

Share this post


Link to post
Share on other sites
#include <Excel.au3>
#include <Array.au3>

Global $oAppl = _Excel_Open()
Global $sWorkbook1 = @ScriptDir & "\Test.xls"
Global $oWorkbook1 = _Excel_BookOpen($oAppl, $sWorkbook1, Default, Default, True)

$aResult = _Excel_RangeRead($oWorkbook1)
_ArrayDisplay ($aResult)
$max = _ArrayMax($aResult, 1)
MsgBox($MB_SYSTEMMODAL, "","$max  is : " & $max)

Please try with this. Check if array displayed correctly.

1 person likes this

Share this post


Link to post
Share on other sites

Sorry,... my mistake .   

The code is worked. 

This is my errors :3 

"$aResult = _Excel_RangeRead($oWorkbook1, $oWorkbook1.Activesheet, "F1:F39", 1)|"
 

 

 

Global $oAppl = _Excel_Open()
Global $sWorkbook1 = @ScriptDir & "\Test.xls"
Global $oWorkbook1 = _Excel_BookOpen($oAppl, $sWorkbook1, Default, Default, True)

$aResult = _Excel_RangeRead($oWorkbook1, $oWorkbook1.Activesheet, "F1:F39", 1)
$max = _ArrayMax($aResult, 0, 1)
MsgBox($MB_SYSTEMMODAL, "","$max  is : " & $max)

 

So... Thank so much Anoop

 

 

Share this post


Link to post
Share on other sites

Or you could let Excel calculate the max value:

Global $oAppl = _Excel_Open()
Global $sWorkbook1 = @ScriptDir & "\Test.xls"
Global $oWorkbook1 = _Excel_BookOpen($oAppl, $sWorkbook1, Default, Default, True)
_Excel_RangeWrite($oWorkbook1, $oWorkbook1.Activesheet, "=MAX(F:F)", "A1", False) ; Modify the target "A1" range if needed
$iMax = _Excel_RangeRead($oWorkbook1, $oWorkbook1.Activesheet, "A1", 1) ; Modify the source "A1" range if needed
MsgBox($MB_SYSTEMMODAL, "","$iMax  is : " & $iMax)
_Excel_BookClose($oWorkbook1, False) ; Close book without saving

 

1 person likes this

My UDFs and Tutorials:

Spoiler

UDFs:
Active Directory (NEW 2017-04-18 - Version 1.4.8.0) - Download - General Help & Support - Example Scripts - Wiki
OutlookEX (NEW 2017-02-27 - Version 1.3.1.0) - Download - General Help & Support - Example Scripts - Wiki
ExcelChart (2015-04-01 - Version 0.4.0.0) - Download - General Help & Support - Example Scripts
Excel - Example Scripts - Wiki
Word - Wiki
PowerPoint (2015-06-06 - Version 0.0.5.0) - Download - General Help & Support

Tutorials:
ADO - Wiki

 

Share this post


Link to post
Share on other sites
30 minutes ago, water said:

Or you could let Excel calculate the max value:

Global $oAppl = _Excel_Open()
Global $sWorkbook1 = @ScriptDir & "\Test.xls"
Global $oWorkbook1 = _Excel_BookOpen($oAppl, $sWorkbook1, Default, Default, True)
_Excel_RangeWrite($oWorkbook1, $oWorkbook1.Activesheet, "=MAX(F:F)", "A1", False) ; Modify the target "A1" range if needed
$iMax = _Excel_RangeRead($oWorkbook1, $oWorkbook1.Activesheet, "A1", 1) ; Modify the source "A1" range if needed
MsgBox($MB_SYSTEMMODAL, "","$iMax  is : " & $iMax)
_Excel_BookClose($oWorkbook1, False) ; Close book without saving

 

Thank Water :) 

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

    • VeryGut
      By VeryGut
      I'm trying to insert the following formula in cell A2 using my script:
      =if(A1=""; "YES"; "NO")
      To my understanding, the line of code should be similar to this:
      _Excel_RangeWrite($MasterFile, Default, "=if(A1=""; "YES"; "NO")", "A2")
      However, it does not work, probably due to the multiple quotation marks that confuse the script :C
      How do I avoid this problem?
    • LoneWolf_2106
      By LoneWolf_2106
      Hi everybody,
      i have a question about Excel, i have to create several charts one below the other dynamically.
      I have thought to use:
       
      $oRangeLast = .UsedRange.SpecialCells($xlCellTypeLastCell) $iRowCount = .Range(.Cells(1, 1), .Cells($oRangeLast.Row, $oRangeLast.Column)).Rows.Count  
      And then to use it in this way:
      $Graph_position = "=Test1!A"&$iRowCount+2&":K"&$iRowCount+24 But it doesn't work with charts.
      Does anyone have a suggestion?
       
    • LoneWolf_2106
      By LoneWolf_2106
      Hi all,
      i have an empty csv file, i have a non formatted text file.
      What do i want to do?
      I want to automate the process "get external data" in Excel, i want to import the data from the text file and basically create a csv file with a specific character encoding.
      Is it possible with AutoIT?
       
    • breakbadsp
      By breakbadsp
      I  want to create a excel file from my script if it does not exist.
      _ExcelBookOpen throws error=2 if file does not exist, after this error i want to create new file at this point.
      can i use _FileCreate()?
      _Logger($sLogPath, "{INFO}------: Opening Excel File: " & $sExcelPath& "") While 1 Local $oExcelTestResult = _ExcelBookOpen($sExcelPath) If @error = 2 Then If not _FileCreate($sResExcelPath) Then MsgBox(0, "Error", "Error In Opening REsult Excel File: Error: " & String(@error)) _Logger($sLogPath, "{ERROR}------: Result Excel File does not exist.. tried to create new but :ERROR : " & String(@error) & "") ExitLoop Else _Logger($sLogPath, "{INFO}------: Result Excel File does not exist.. **Created New**: ") EndIf Else ExitLoop EndIf WEnd  
    • LoneWolf_2106
      By LoneWolf_2106
      Hi everybody,
      i have to store an entire row of a Excel workbook into an array.  The row index is stored in a variable.
      How can i do it?
      Thanks in advance for your support.