PowerCat Posted December 10, 2012 Share Posted December 10, 2012 (edited) I'm trying to make a script, however having difficulty. I have two arrays, one of the terms that I'd like to match, and the other one an array of sentences. I've made this so far, however it keeps finding only position 0, 6 and 2... I don't get why, and I would welcome any better way to do this, as I can't seem to wrap my head around doing this properly... expandcollapse popup#include <Array.au3> Dim $SearchTerms[3] $SearchTerms[0] = "Term1" $SearchTerms[1] = "Term2" $SearchTerms[2] = "Term3" Dim $SearchList[10] $SearchList[0] = "This sentence may contain term1" $SearchList[1] = "This one doesn't match anything" $SearchList[2] = "This one may match term1 and term3" $SearchList[3] = "This one matches term3" $SearchList[4] = "No match here" $SearchList[5] = "I'm running out of things to write" $SearchList[6] = "Term2 comes up here" $SearchList[7] = "I can't see what's going on" $SearchList[8] = "Blah blah blah term3" $SearchList[9] = "no" $MatchedPosition = "" For $i = 0 to ubound($SearchList)-1 ;enter FOR loop. it will loop 10 times for $searchlist ConsoleWrite("-- Processing array SearchList, at position " & $i & ". Val = " & $SearchList[$i] & @CRLF) For $j = 0 to ubound($searchterms)-1 ConsoleWrite('Looking for "' & $searchterms[$j] & '" in "' & $SearchList[$i] & '"' & @CRLF) ; enter sub FOR loop, it will compare the current search item to the terms $isMatch = _ArraySearch($SearchList, $SearchTerms[$j], 0, ubound($SearchList)-1, 0, 1) ConsoleWrite("> found at " & $isMatch & @CRLF) Next Next Edited December 10, 2012 by PowerCat Link to comment Share on other sites More sharing options...
PowerCat Posted December 10, 2012 Author Share Posted December 10, 2012 I was able to get this to work the way I'd like, but I'm still wondering if there's any better way: expandcollapse popup#include <Array.au3> Dim $SearchTerms[3] $SearchTerms[0] = "Term1" $SearchTerms[1] = "Term2" $SearchTerms[2] = "Term3" Dim $SearchList[10] $SearchList[0] = "This sentence may contain term1" $SearchList[1] = "This one doesn't match anything" $SearchList[2] = "This one may match term1 and term3" $SearchList[3] = "This one matches term3" $SearchList[4] = "No match here" $SearchList[5] = "I'm running out of things to write" $SearchList[6] = "Term2 comes up here" $SearchList[7] = "I can't see what's going on" $SearchList[8] = "Blah blah blah term3" $SearchList[9] = "no" $MatchedPosition = "" For $i = 0 to ubound($SearchList)-1 ;enter FOR loop. it will loop 10 times for $searchlist ConsoleWrite("-- Processing array SearchList, at position " & $i & ". Val = " & $SearchList[$i] & @CRLF) For $j = 0 to ubound($searchterms)-1 ConsoleWrite('Looking for "' & $searchterms[$j] & '" in "' & $SearchList[$i] & '"' & @CRLF) ; enter sub FOR loop, it will compare the current search item to the terms $isMatch = _ArraySearch($SearchList, $SearchTerms[$j], 0, ubound($SearchList)-1, 0, 1) $isMatch = _ArrayFindAll($SearchList, $SearchTerms[$j], "", "", "", 1) if IsArray($ismatch) then $Positions = _ArrayToString($ismatch) $MatchedPosition = $MatchedPosition & $Positions & "|" Else EndIf ConsoleWrite("> found at " & $isMatch & @CRLF) Next Next $MatchedPosition = StringTrimRight($MatchedPosition, 1) $Matches = StringSplit($MatchedPosition, "|", 2) $matches = _ArrayUnique($Matches) _ArrayDelete($Matches, 0) _ArrayDisplay($matches) Link to comment Share on other sites More sharing options...
Moderators Melba23 Posted December 10, 2012 Moderators Share Posted December 10, 2012 PowerCat, I would use an SRE like this: expandcollapse popup#include <Array.au3> Global $SearchTerms[3] $SearchTerms[0] = "Term1" $SearchTerms[1] = "Term2" $SearchTerms[2] = "Term3" Global $SearchList[10] $SearchList[0] = "This sentence may contain term1" $SearchList[1] = "This one doesn't match anything" $SearchList[2] = "This one may match term1 and term3" $SearchList[3] = "This one matches term3" $SearchList[4] = "No match here" $SearchList[5] = "I'm running out of things to write" $SearchList[6] = "Term2 comes up here" $SearchList[7] = "I can't see what's going on" $SearchList[8] = "Blah blah blah term3" $SearchList[9] = "no" ; Get the search terms into a SRE pattern $sPattern = "(" For $i = 0 To UBound($SearchTerms) - 1 $sPattern &= $SearchTerms[$i] & "|" Next $sPattern = StringTrimRight($sPattern, 1) & ")" ; Now compare the pattern to each element $MatchedPosition = "" For $i = 0 To UBound($SearchList) - 1 ConsoleWrite("-- Processing array SearchList, at position " & $i & ". Val = " & $SearchList[$i] & @CRLF) If StringRegExp($SearchList[$i], "(?i)" & $sPattern) Then $MatchedPosition &= $i & "|" ConsoleWrite("> found at " & $i & @CRLF) EndIf Next ; Convert to an array $MatchedPosition = StringTrimRight($MatchedPosition, 1) $Matches = StringSplit($MatchedPosition, "|", 2) _ArrayDisplay($Matches) M23 Any of my own code posted anywhere on the forum is available for use by others without any restriction of any kind Open spoiler to see my UDFs: Spoiler ArrayMultiColSort ---- Sort arrays on multiple columnsChooseFileFolder ---- Single and multiple selections from specified path treeview listingDate_Time_Convert -- Easily convert date/time formats, including the language usedExtMsgBox --------- A highly customisable replacement for MsgBoxGUIExtender -------- Extend and retract multiple sections within a GUIGUIFrame ---------- Subdivide GUIs into many adjustable framesGUIListViewEx ------- Insert, delete, move, drag, sort, edit and colour ListView itemsGUITreeViewEx ------ Check/clear parent and child checkboxes in a TreeViewMarquee ----------- Scrolling tickertape GUIsNoFocusLines ------- Remove the dotted focus lines from buttons, sliders, radios and checkboxesNotify ------------- Small notifications on the edge of the displayScrollbars ----------Automatically sized scrollbars with a single commandStringSize ---------- Automatically size controls to fit textToast -------------- Small GUIs which pop out of the notification area Link to comment Share on other sites More sharing options...
BrewManNH Posted December 10, 2012 Share Posted December 10, 2012 Here's my version. #include <Array.au3> Dim $SearchTerms[3] $SearchTerms[0] = "Term1" $SearchTerms[1] = "Term2" $SearchTerms[2] = "Term3" Dim $SearchList[10] $SearchList[0] = "This sentence may contain term1" $SearchList[1] = "This one doesn't match anything" $SearchList[2] = "This one may match term1 and term3" $SearchList[3] = "This one matches term3" $SearchList[4] = "No match here" $SearchList[5] = "I'm running out of things to write" $SearchList[6] = "Term2 comes up here" $SearchList[7] = "I can't see what's going on" $SearchList[8] = "Blah blah blah term3" $SearchList[9] = "no" $MatchedPosition = "" For $i = 0 To UBound($SearchList) - 1 ;enter FOR loop. it will loop 10 times for $searchlist ConsoleWrite("-- Processing array SearchList, at position " & $i & ". Val = " & $SearchList[$i] & @CRLF) For $j = 0 To UBound($SearchTerms) - 1 ConsoleWrite('Looking for "' & $SearchTerms[$j] & '" in "' & $SearchList[$i] & '"' & @CRLF) If StringInStr($searchlist[$i], $SearchTerms[$j]) Then $MatchedPosition &= $i & "|" EndIf ConsoleWrite("> found at " & $i & @CRLF) Next Next $MatchedPosition = StringTrimRight($MatchedPosition, 1) $Matches = StringSplit($MatchedPosition, "|", 2) $Matches = _ArrayUnique($Matches) _ArrayDelete($Matches, 0) _ArrayDisplay($Matches) No SRE, but it works. 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 Link to comment Share on other sites More sharing options...
PowerCat Posted December 10, 2012 Author Share Posted December 10, 2012 Ahh, the stringregex method is so classy, but a bit complex. I'll be able to adapt it, thanks for that. Thank you two for the suggestions, that ArrayFind was definitely not a good way to go about it! 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