用正则表达式替换的文件中的文本。如何将更改写入文件?---扩展问题

时间:2019-02-14 13:20:06

标签: python regex cesium

Reference

这是Cesiumjs特定的file.czml。 它包含以米为单位的标高。它们是1407.0和1408.2和1409.6 ---等等。 高程分为两行。

var czml = [{
"id" : "document",
"name" : "CZML Geometries: Polyline",
"version" : "1.0"
}
,

{snip---"cartographicDegrees": [0, 12.039186, 47.663944, 1407.0, 30.0, 12.038963, 47.663952, 1408.2, 60.0, 12.038646, 47.663924, 1409.6, 90.0, 12.038504, 47.663926, 1412.2, 120.0, snip---}
,
{
{snip--- "cartographicDegrees": [0, 12.035275, 47.661445, 1557.2, 30.0, 12.035461, 47.661414, 1550.4, 60.0, 12.03565, 47.661382, 1551.4, 90.0, 12.035831, 47.661391, 1546.6, 120.0, snip---}];

我想给每个加40,所以结果应该在两行中: 1447.0代替1407.0,1448.2代替1408.0,1449.6代替1409.6 ---依此类推。 但是我的代码只更改了第一个值- 每行1407.0到1447.0。

以下我的Python代码有什么问题?

import re
f1 = input("name of your CZML file---> ")
input_file = open(f1,'r+')
output_file = open(f1 + '_output', 'w+')
line = input_file.readline()
while line:
    res = re.search(r"([0-9]{4}\.[0-9]{1,})", line)
    #res = re.findall(r"([0-9]{4}\.[0-9]{1,})", line)   
    for i in range(len(line)):
        number = line[i : (i+6)]
        if re.search(r"([0-9]{4}\.[0-9]{1})", number):
            number=float(number)
            numberelev = number+40
            numberelev=str(numberelev)
        line = line.replace(res.group(1), numberelev)
    output_file.write(line)
    line = input_file.readline()
input_file.close()
output_file.close()
print("OK")

约瑟夫,谢谢你的帮助

1 个答案:

答案 0 :(得分:0)

问题是用于替换字符串出现的代码line = line.replace(res.group(1), numberelev)使用res.group(1),该代码在range(len(line))的迭代过程中不会更改,因为它是在之前初始化的循环:因此,您的代码可以找到所有匹配项,但仅替换第一个匹配项。

为了解决此问题,应按以下步骤更改主体循环:

for i in range(len(line)):
    number = line[i : (i+6)]
    find = re.search(r"([0-9]{4}\.[0-9]{1})", number)
    if find:
        number=float(number)
        numberelev = number+40
        numberelev=str(numberelev)
        line = line.replace(find.group(1), numberelev)

关键点是替换find.group(1)(当循环进行时会更改),而不是res.group(1)(对于每行 都假设您第一次出现的值)模式)。

希望这对您有帮助!