Solved

Finding text files with matching string including wildcards (Win10)

Posted on 2016-11-15
16
47 Views
Last Modified: 2016-11-15
Win10:

I have a directory with a bunch of HTML files. I need to identify any file with next matching a specific token.

I can use the legacy FIND command from the command prompt e.g.

FIND "My Target String" *.HTML

but I need also to find "My+Target+String", "My-Target-String" etc.

Is there a variant of the FIND command that will support wildcards e.g.

FIND "My?Target?String" *.HTML

I'll gladly accept either a command line (maye PowerShell?) or Windows (GUI) solution.

Thanks,
Steve
0
Comment
Question by:Stephen Kairys
  • 7
  • 6
  • 2
  • +1
16 Comments
 
LVL 8

Expert Comment

by:James Bilous
ID: 41888215
1
 
LVL 83

Assisted Solution

by:oBdA
oBdA earned 500 total points
ID: 41888222
findstr.exe supports something vaguely resembling regular expressions; the "." stands for any single character:
findstr.exe /i /r /c:"My.Target.String" *.html

Open in new window

If the target string shows up repeatedly in a single file, and you only want the file names, paste this into a command prompt:
for %a in (*.html) do @(findstr.exe /i /r /c:"My.Target.String" "%a" >NUL&if not errorlevel 1 echo %a)

Open in new window

0
 
LVL 4

Author Comment

by:Stephen Kairys
ID: 41888226
OBDA - Trying your solution now on a test fileset. Thanks.
0
 
LVL 4

Author Comment

by:Stephen Kairys
ID: 41888232
Follow-up:
I can't seem to get HELP for FINDSTR from the PowerShell prompt per the below.

PowerShell HELP problem
Accordingly, can I assume the /i option means "ignore case"?

Thanks again.
0
 
LVL 8

Expert Comment

by:James Bilous
ID: 41888237
findstr is a DOS command, not powershell. If you want to use powershell you should use gci (get-childitem) like I suggested.
1
 
LVL 83

Expert Comment

by:oBdA
ID: 41888238
Since you were using find, the commands I posted assume the Command prompt as well, not Powershell.
0
 
LVL 4

Author Comment

by:Stephen Kairys
ID: 41888240
All,
Going for FINDSTR, seems simpler. Thanks for the heads-up that FINDSTR is DOS not PowerShell. :)
0
 
LVL 83

Expert Comment

by:oBdA
ID: 41888253
For Powershell, the equivalent would be
Select-String -Pattern "My.Target.String" -List -Path *.html

Open in new window

0
Ransomware-A Revenue Bonanza for Service Providers

Ransomware – malware that gets on your customers’ computers, encrypts their data, and extorts a hefty ransom for the decryption keys – is a surging new threat.  The purpose of this eBook is to educate the reader about ransomware attacks.

 
LVL 4

Author Comment

by:Stephen Kairys
ID: 41888280
@OBDA- Your first (simpler) solution

findstr.exe /i /r /c:"My.Target.String" *.html

Open in new window

worked nicely. However, b/c of multiple string occurreences I figured I'd try the FOR loop. However....it threw an error.

T:\>
T:\>do @(findstr.exe /i /r /c:"Ad.Tag.Setup" "%a" >NUL&if not errorlevel 1 echo %a)
'do' is not recognized as an internal or external command,
operable program or batch file.


Also, just curious. I understand that the period (.) means wildcard. If I were truly seaching on a string that includes a period and don't care about wildcards, i guess I'd remove the /r switch?

Thanks again. I think we're almost there!
0
 
LVL 83

Expert Comment

by:oBdA
ID: 41888292
You left out the "for %a in (*.html) " at the beginning of the command.
for %a in (*.html) do @(findstr.exe /i /r /c:"My.Target.String" "%a" >NUL&if not errorlevel 1 echo %a)

Open in new window

To specify a literal "." in a RegEx, you escape it with a backslash.
This would expect the target string to end with a period:
findstr.exe /i /r /c:"My.Target.String\." *.html

Open in new window

0
 
LVL 52

Expert Comment

by:Bill Prew
ID: 41888294
If you need to search for multiple strings you can place a list of the desired strings or patterns into a text file and then use FINDSTR with the /g: option telling it to get the search strings from that file rather than the command line.  If it just a couple though you can also do that with multiple /c: parms on a single command line.

~bp
1
 
LVL 83

Accepted Solution

by:
oBdA earned 500 total points
ID: 41888303
Forget about the "for" loop. findstr.exe can do the file list all by its lonesome, with /m (not using findstr too often, because of the very limited "regular expression" support):
findstr.exe /m /i /r /c:"My.Target.String" *.txt

Open in new window

0
 
LVL 4

Author Closing Comment

by:Stephen Kairys
ID: 41888334
@ODBA - Thank you for persisting to solve this issue. (And I love how "old" technology can still be our friend! :)

@James and @Bill - thanks for your comments. I wasn't able to try out your solutions; however, I appreciate your efforts to help. (If you disagree that I'm not assigning you credit or points, please feel free to object.)

Steve
1
 
LVL 4

Author Comment

by:Stephen Kairys
ID: 41888814
@OBDA - OK, I'm playing around with this solution and I have two follow-ups.

1. Is there an option to tell me how many instances are in each matched file?

2. For your FOR loop solution, I tried it in a batch file; however, it threw the following message:
H:\>find-ats-for.bat
"My.Target.String" was unexpected at this time.

Open in new window


Thanks again.
0
 
LVL 83

Expert Comment

by:oBdA
ID: 41888856
This will give you the number of lines, not the number instances.
@echo off
setlocal enabledelayedexpansion
set Search=D:\Temp\*.html
for %%a in ("%Search%") do (
	set /a Count = 0
	for /f %%a in ('findstr.exe /i /r /c:"My.Target.String" "%%~a"') do set /a Count += 1
	if !Count! gtr 0 echo %%~nxa: !Count!
)

Open in new window

The other error is because in a script, you need double percent signs for the loop variables.
for %%a in (*.html) do @(findstr.exe /i /r /c:"My.Target.String" "%%a" >NUL&if not errorlevel 1 echo %%a)

Open in new window

0
 
LVL 4

Author Comment

by:Stephen Kairys
ID: 41888864
@oBdA - Thank you. I need the # of instances, but that's OK. I can always look through the HTML page manually....none of them are that big. FIgured it was worth a shot.
0

Featured Post

Netscaler Common Configuration How To guides

If you use NetScaler you will want to see these guides. The NetScaler How To Guides show administrators how to get NetScaler up and configured by providing instructions for common scenarios and some not so common ones.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Is your Office 365 signature not working the way you want it to? Are signature updates taking up too much of your time? Let's run through the most common problems that an IT administrator can encounter when dealing with Office 365 email signatures.
In this article, I will show you HOW TO: Install VMware Tools for Windows on a VMware Windows virtual machine on a VMware vSphere Hypervisor 6.5 (ESXi 6.5) Host Server, using the VMware Host Client. The virtual machine has Windows Server 2016 instal…
The viewer will learn the benefit of using external CSS files and the relationship between class and ID selectors. Create your external css file by saving it as style.css then set up your style tags: (CODE) Reference the nav tag and set your prop…
Video by: Mark
This lesson goes over how to construct ordered and unordered lists and how to create hyperlinks.

863 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

24 Experts available now in Live!

Get 1:1 Help Now