python正則表達式替換字元串
㈠ 用python正則表達式替換字元串問題 我用python寫一個計算器,想用正則表達式將字元串中的一些內容替換,
先用正則表達式 sin((d+(.d+)?)) 取第一捕獲組的數據
把sin(45)中的角度值angle匹配出來,然後計算出sin(angle)的值value,
最後用正則表達式 "sin("+angle+")" 替換成String.valueOf(value) //value的字元串形式
我給你一個完整的java語言的例子,你看看吧.
importjava.util.regex.Matcher;
importjava.util.regex.Pattern;
publicclassAA{
publicstaticvoidmain(String[]args){
Strings="1+2*3-(5/6)+sin(45)-ln(100)";
Stringregex="sin\((\d+(\.\d+)?)\)";
Patternp=Pattern.compile(regex);
Matcherm=p.matcher(s);
while(m.find()){
Stringangle=m.group(1);//取出sin函數的角度值
doubled=Double.parseDouble(angle);//把角度值轉換成double型
doublevalue=Math.sin(d/180*Math.PI);//把角度值轉換成弧度值然後計算sin函數值
s=s.replaceAll("sin\("+angle+"\)",String.valueOf(value));//把相應的sin(45)字元串替換成sin函數值
System.out.println(s);//輸出結果,你也可以在程序最後輸出結果,也就是在while循環完成後輸出結果
}
}
}
運行結果
1+2*3-(5/6)+0.7071067811865475-ln(100)
㈡ python,字元串正則,替換最後一個特定字元
在 python 中, str.replace 函數接受的第一個參數並不是正則表達式,而是字元串。
所以你會看到,運行
print'123(abc)123'.replace('(abc)','!')
的結果是
'123!123'
想要達到你所說的效果,可以試一試 python 中的 re 模塊
例如:
importre
replace_reg=re.compile(r'abc$')
printreplace_reg.sub('X','123abc')
的運行結果為:
'123X'
㈢ python的字元串替換問題
樓主搞生物的?很像鹼基對啊。replace是替換整串字元串的,但是這里不方便,因為你把AA替換成TT後,就變成TTTT,然後再替換,變為AAAA,沒有達到效果,除非你用另外的字元代替,不過,這樣就沒有python的簡潔優美了,所以這個問題用re最方便,下面是代碼:
#coding=utf-8
importre
astr='AATTCCGG'
charmap={'AA':'TT','TT':'AA','CC':'GG','GG':'CC'}
new=re.sub(r'AA|TT|CC|GG',lambdax:charmap[x.group(0)],astr)
print(new)#python2為printnew
㈣ python如何用正則表達式匹配兩個字元串之間的字元串中的某個字元並進行替換
你好,匹配和替換是兩個操作,你可以分兩步來做。
第一步匹配:
hit=re.search(「(\<question\>\<img.*?question_id=「100」\>)」,inputstr)
第二步替換
result=re.sub(『」』,『\」』,inputstr)
㈤ python正則表達式是什麼
python正則表達式是使用單個字元串來描述、匹配某個句法規則的字元串,常被用來檢索、替換那些符合某個模式(規則)的文本。最初的正則表達式出現於理論計算機科學的自動控制理論和形式化語言理論中。
1950 年,數學家斯蒂芬·科爾·克萊尼利用稱之為「正則集合」的數學符號來描述此模型。肯·湯普遜將此符號系統引入編輯器 QED,隨後是 UNIX 上的編輯器 ed,並最終引入 grep。自此以後,正則表達式被廣泛地應用於各種 UNIX 或類 UNIX 系統的工具中。目前,許多程序設計語言都支持利用正則表達式進行字元串操作。
正則表達式常用的特殊字元:
:將下一個字元標記為一個特殊字元、一個原義字元(Identity Escape,有 "^" "$" "(" ")" "*" "+" "{" "|" 共計12個)、一個向後引用(backreferences)或一個八進制轉義符。例如「n」匹配字元「n」,「 」匹配一個換行符,「\」匹配「」,「(」則匹配「(」。
^:匹配輸入字元串的開始位置。如果設置了正則表達式的多行屬性,「^」也可以匹配「 」或「 」之 後的位置。
[a-z]:字元范圍,匹配指定范圍內的任意字元。例如「[a-z]」可以匹配「a」到「z」范圍內的任意小寫字母字元。
s:匹配任何空白字元,包括空格、製表符、換頁符等,等效於「[f v]」。注意 Unicode 正則表達式 會匹配全形空格符。
㈥ python正則表達式是什麼呢
python正則表達式如下:
在python中,所謂的「正則表達式」指的是通常被用來檢索、替換那些符合某個模式的一段文本。具體而言,它的作用是檢測某個字元串是否符合規則和提取網頁字元串中想要的數據。
正則表達式是對字元串提取的一套規則,我們把這個規則用正則裡面的特定語法表達出來,去匹配滿足這個規則的字元串。正則表達式具有通用型,不僅python裡面可以用,其他的語言也一樣適用。
python的編程特點:
速度快:Python的底層是用C語言寫的,很多標准庫和第三方庫也都是用C寫的,運行速度非常快。
免費、開源:Python是FLOSS(自由/開放源碼軟體)之一。使用者可以自由地發布這個軟體的拷貝、閱讀它的源代碼、對它做改動、把它的一部分用於新的自由軟體中。FLOSS是基於一個團體分享知識的概念。
高層語言:用Python語言編寫程序的時候無需考慮諸如如何管理你的程序使用的內存一類的底層細節。
解釋性:一個用編譯性語言比如C或C++寫的程序可以從源文件(即C或C++語言)轉換到一個你的計算機使用的語言(二進制代碼,即0和1)。這個過程通過編譯器和不同的標記、選項完成。
㈦ python 正則表達式re.sub函數替換內容的一個比較基礎的問題
正則表達式一個比較常見的用途是找到所有模式匹配的字元串並用不同的字元串來替換它們。sub方法提供一個替換值,可以是字元串或函數,和一個要被處理的字元串。
1、這里的sub方法,是被編譯成『RegexObject』實例後的實例的方法
Sub(replacement,string[,count =0 ])
1)返回的字元串是在字元串中用RE最左邊不重復的匹配來替換。如果模式沒有被發現,字元將沒有被改變的返回。
2)可選參數count是模式匹配後替換的最大次數;count必須是非負整數。預設值是0表示替換所有的匹配。
例子:
2、模塊級函數:sub方法
註:這些函數(包括sub函數)使用RE字元串作為第一個參數,而後面的參數與相應的「RegexObject」方法的參數相同,返回要麼是None,要麼是一個『MatchObject』實例。
(實際sub返回的是字元串,,兩者說法不一致,以實際為准)
Re.sub的作用在於:使用給定的替換內容將匹配模式的子字元串(最左端並且非重疊的子字元串)替換掉
3、作為替換的組號
在2的例子中,只是把一個字元串用其他的內容替換掉了。用replace這個字元串方法能輕松達到同樣的效果。而正則表達式允許以更靈活的方式進行搜索,同時它們也允許進行功能更強大的替換。
見證re.sub強大功能的最簡單方式就是在替換字元串中使用組號。在替換內容中以『\\n』型式出現的任何轉義序列都會被模式中與組n匹配的字元串替換掉。例如,假設要把『*something*』用『<em>someting</em>』替換掉,前者是在普通文本文檔(比如Email)中進行強調的常用方法,而後者則是相應的HTML代碼(用於網頁)
這里把所有的* *含的字元串都替換掉了。剛開始我以為只替換*world*。記一筆。
㈧ python中如何使用正則表達式從字元串中刪除特定字元
可以使用 one_str.replace("EventApplyCheckIn:\/\/", "") 把它替換為空就好
㈨ python正則表達式替換字元串問題
按照你的要求在不改變name()函數的前提下,把兩個"xyz"都替換為"xyz111"的Python程序如下
importre
defname(matched):
newname=matched.group('name')+'111'
returnnewnamestr='helloxyz,nihaoxyz'
strnew=re.sub(r"(?<=hello|nihao)(?P<name>w+)",name,str)
print(strnew)
運行結果
helloxyz111,nihaoxyz111
㈩ python正則表達式如何用已知字元串(如"aaa")替換文件中匹中的分組內容,不是匹中的全部,而是其中一個組
import re
s = '1234567890'
pattern = re.compile(r'(34)(\d+)(78)')
print(pattern.sub(r'\1aaa\3',s))
把兩邊的也加括弧,替換的時候加上 \1 \3就行