校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > 批處理FINDSTR正則表達式用法實例分析

批處理FINDSTR正則表達式用法實例分析

熱門標簽:百應ai電話機器人銷售怎么樣 谷歌地圖標注時間 好的人工智能電話機器人 云南旅游地圖標注app 地圖標注位置有用嗎 廣州云外呼系統(tǒng)公司 地圖標注銷售數(shù)據(jù) 中國地圖標注省份顏色 岳陽縣地圖標注app

1.findstr . 2.txt 或 Findstr "." 2.txt

從文件2.txt中查找任意字符,不包括空字符或空行

2.findstr .* 2.txt 或 findstr ".*" 2.txt

從文件2.txt中查找任意字符包括空行和空字符

3.findstr "[0-9]" 2.txt

從文件2.txt中查找包括數(shù)字0-9的字符串或行

4.findstr "[a-zA-Z]" 2.txt

從文件2.txt中查找包括任意字符的字符串或行

5.findstr "[abcezy]" 2.txt

從文件2.txt中查找包括a b c e z y字母的字符串或行

6.findstr "[a-fl-z]" 2.txt

從文件2.txt中查找小寫字符a-f l-z的字符串,但不包含g h I j k這幾個字母。

7.findstr "M[abc][hig]Y" 2.txt

從文件2.txt中可以匹配 MahY , MbiY, MahY等…..

8. ^和$符號的應用

^ 表示行首,"^step"僅匹配 "step hello world"中的第一個單詞
$ 表示行尾,"step$"僅匹配 "hello world step"中最后一個單詞

9.findstr "[^0-9]" 2.txt

如果是純數(shù)字的字符串或者行便過濾掉,例如2323423423 這樣的字符串,如果是345hh888這樣的形式就不成了。

10.findstr "[^a-z]" 2.txt

同上,如果是純字母的字符串或者行便過濾掉,例如 sdlfjlkjlksjdklfjlskdf這樣的字符,如果是sdfksjdkf99999這樣的形式,摻雜著數(shù)字就不成了

11.*號的作用

前面已經說過了 ".*"表示搜索的條件是任意字符,*號在正則表達式中的作用不是任何字符,而是表示左側字符或者表達式的重復次數(shù),*號表示重復的次數(shù)為零次或者多次。

12.findstr "^[0-9]*$" 2.txt

這個是匹配找到的純數(shù)字,例如 234234234234,如果是2133234kkjl234就被過濾掉了。
Findstr "^[a-z]*$" 2.txt
這個是匹配找到的純字母,例如 sdfsdfsdfsdf,如果是213sldjfkljsdlk就被過濾掉了
如果在搜索條件里沒有*號,也就是說不重復左側的搜索條件,也就是[0-9] [a-z]那只能匹配字符串的第一個字符也只有這一個字符,因為有行首和行尾的限制,"^[0-9]$"第一個字符如果是數(shù)字就匹配,如果不是就過濾掉,如果字符串是 9 就匹配,如果是98或者9j之類的就不可以了。

13. "\…\&;"這個表達式的作用

這個表示精確查找一個字符串,\sss 表示字的開始位置,sss\&;表示字的結束位置
echo hello world computer|findstr "\computer\&;"這樣的形式
echo hello worldcomputer|findstr "\computer\&;" 這樣的形式就不成了,他要找的是 "computer"這個字符串,所以不可以。
echo hello worldcomputer|findstr ".*computer\&;"這樣就可以匹配了

【補充】

上文提到 . 作為元字符,可以用來匹配任意單個字符,比如:

findstr "2.1" test.txt

可以匹配到:
2.1
201
2a1
等等,包含這些字符串的行。

但是在某些場景下,我們希望 . 作為一個普通的字符,比如匹配某個版本號:

findstr "2\.1" test.txt

可以在 . 前面加一個轉義符號 \ 來實現(xiàn)這個效果,只匹配 2.1 這個版本號,過濾掉201、2a1等不符合要求的行。

擴展閱讀:批處理常用符號詳解

【實例補充】
匹配以張三或李四開頭的行:

findstr "^張三 ^李四" "1.txt" > "2.txt"

刪除所有以#開頭,并且有且只有一個#的行:

http://bbs.bathome.net/thread-59458-1-1.html

findstr /b /e /v "#[^#]*" 1.txt

上面的問題如下

有個文件1.txt,內容是
12
123#
#123
##12
#12#34#
# aaaa
#
####

要刪除所有以#開頭,并且有且只有一個#的行

處理后變成
12
123#
##12
#12#34#
####

應該用for 實現(xiàn)嗎?

@echo off
findstr /bev "#[^#]*" a.txt
pause
@echo off
for /f "delims= tokens=*" %%a in ('type "1.txt"^|findstr /b /e /v "#[^#]*"') do echo,%%a >>.\2.txt
exit

到此這篇關于批處理FINDSTR正則表達式用法實例分析的文章就介紹到這了,更多相關批處理 FINDSTR用法內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • 批處理 正則表達式(findstr) 整理

標簽:三明 鄭州 周口 東營 天門 宜昌 南京 三沙

巨人網絡通訊聲明:本文標題《批處理FINDSTR正則表達式用法實例分析》,本文關鍵詞  批處理,FINDSTR,正則,表達式,;如發(fā)現(xiàn)本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《批處理FINDSTR正則表達式用法實例分析》相關的同類信息!
  • 本頁收集關于批處理FINDSTR正則表達式用法實例分析的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 禹州市| 徐汇区| 珲春市| 错那县| 宁明县| 长岭县| 北安市| 泰和县| 洞头县| 乐山市| 阳城县| 石狮市| 阿坝县| 凤山县| 石屏县| 花莲县| 德惠市| 封丘县| 洪洞县| 津市市| 子长县| 休宁县| 义乌市| 哈密市| 蚌埠市| 阜城县| 庆元县| 宝山区| 辉南县| 廉江市| 新宁县| 德安县| 乌兰浩特市| 成安县| 桐柏县| 万宁市| 井研县| 抚远县| 白玉县| 鹤峰县| 武川县|