在一個文件里有很多以下內(nèi)容:
p style="display:none">此題選D。
....
....
....
/p>
而本人要實現(xiàn)的功能是將它替換成:
div style="display:none" class="sl_explain">此題選D。
.....
.....
.....
/div>
這個東西看起來有點簡單,但本人整整花了半天才實現(xiàn)此功能,主要是很久沒寫RUBY程序了,所以對API比較陌生;其次是本人對正則表達(dá)式,尤其是ruby的正則表達(dá)式不太熟悉;最后,還因為一些細(xì)節(jié)考慮得不夠。
要實現(xiàn)上述功能,可以分為兩步,第一步是將
p style="display:none">此題選D。
....
....
....
/p>
中的\n替換掉,即替換成:
p style="display:none">此題選D。............/p>
這種形式,為什么要替換換\n呢,因為在讀文件是,需要一行一行讀,所以有\(zhòng)n的話,這一行就讀不完,那么在用正則表達(dá)式匹配時,自然會匹配不全。要實現(xiàn)替換掉而且只替換掉
p style="display:none">此題選D。............/p>
內(nèi)部的\n,需要一些限制,具體實現(xiàn)代碼如下:
File.open("邏輯填空2.htm","w") do |test|
File.open("邏輯填空.htm",'r:gbk') do |file|
file.each_line do | line|
if(line.start_with?('p style="display:none">') !line.end_with?("/p>\n"))
line.gsub!(Regexp.new('\n'), '')
end
test.print line
end
end
end
即將替換掉的內(nèi)容放在新的一個文件“邏輯填空2.html”中(注意1,上面輸出到文件時,使用的是print,而不是puts,不然它又會自然加上一個\n,那就白替換了;注意2,上面的end_with后面還加個\n,因為讀取這行結(jié)尾時,還有個隱形的換行符\n;注意3,有時候p style="display:none">前面會有空格,所以可以將start_with改成include?),然后再讀取此文件,再通過正則表達(dá)式進(jìn)行替換,將替換掉的內(nèi)容又放在“test.html”中:
File.open("test.html","w") do |test|
File.open("邏輯填空2.htm",'r') do |file|
file.each_line do | line|
line.gsub!(Regexp.new('p style="display:none">(.*)/p>'), 'div style="display:none" class="sl_explain">\1/div>')
test.puts line
end
end
end
這樣,本人要實現(xiàn)的功能就達(dá)到了,另外,如果如果文件不是一行一行讀取的,倒是可以用多行匹配的方式來做:
Regexp.new('p style="display:none">(.*)/p>',Regexp::MULTILINE)
可惜,本人只想出了逐行讀取的方法,所以多行匹配模式?jīng)]用上。
您可能感興趣的文章:- 詳解Ruby中正則表達(dá)式對字符串的匹配和替換操作
- Ruby的字符串與數(shù)組求最大值的相關(guān)問題討論
- Ruby中的字符串編寫示例
- Ruby中操作字符串的一些基本方法
- Ruby中常用的字符串處理函數(shù)使用實例
- Ruby簡潔學(xué)習(xí)筆記(一):字符串、數(shù)字、類和對象
- Ruby中創(chuàng)建字符串的一些技巧小結(jié)
- Ruby中實現(xiàn)把字符串轉(zhuǎn)換為類的2種方法
- Ruby中字符串左側(cè)補(bǔ)零方法實例
- Ruby字符串、條件、循環(huán)、數(shù)組、Hash、類基本操作筆記
- Ruby 字符串處理