(Публикация на случай, если кому-то это пригодится).
Я искал решение проблемы немного более сложного, чем OP - замена КАЖДОГО вхождения чего-либо с числом на то же самое с увеличенным числом
Например, заменив что-то вроде этого:
<row id="1" />
<row id="2" />
<row id="1" />
<row id="3" />
<row id="1" />
Этим:
<row id="2" />
<row id="3" />
<row id="2" />
<row id="4" />
<row id="2" />
Не удалось найти решение в Интернете, поэтому я написал свой собственный сценарий на Groovy (немного некрасиво, но выполняет свою работу):
def replace_inc(String text, int startingIndex, String findTemplate) {
assert findTemplate.contains('_') : 'search template needs to contain "_" placeholder'
assert !(findTemplate.replaceFirst('_','').contains('_')) : 'only one "_" placeholder is allowed'
assert !text.contains('_____') : 'input text should not contain "______" (5 underscores)'
while (true) {
findString = findTemplate.replace("_",(startingIndex).toString())
if (!text.contains(findString)) break;
replaceString = findTemplate.replace("_", "_____"+(++startingIndex).toString())
text = text.replaceAll(findString, replaceString)
}
return text.replaceAll("_____","")
}
findTemplate = 'Row="_"'
path = /C:\TEMP\working_copy.txt/
startingIndex = 0
f = new File(path)
outText = replace_inc(f.text,startingIndex,findTemplate)
println "Results \n: " + outText
f.withWriter { out -> out.println outText }
println "Results written to $f"