如何替换文本中每行空格前的第一个数字

2024-04-29 16:48:37 发布

您现在位置:Python中文网/ 问答频道 /正文

我的文件如下所示:

12.32 1:34 2:49 5:21 29:98
13.53 1:23 2:82 5:23 29:45
51.92 1:23 2:54 5:54 29:63
12.42 1:34 2:43 5:32 29:32

我试图用另一个数字替换每行中的第一个数字。所以输出会是

21.33 1:34 2:49 5:21 29:98
16.23 1:23 2:82 5:23 29:45
93.12 1:23 2:54 5:54 29:63
18.76 1:34 2:43 5:32 29:32 

什么是好方法?你知道吗

我试着用手指着那个号码

with open('file.txt', 'r') as file:
    line = file.readline()
    line[0]

但它只给了我第一个字符,而不是整个数字。 非常感谢!你知道吗


Tags: 文件方法txtreadlineaswithline数字
3条回答

这段代码应该可以做到这一点,但它可能有点错误,可能需要调整和测试一点。不过,我希望能有所帮助。你知道吗

with open('file.txt', 'r') as file:
    file_content = file.read()
    list_content = [letter for letter in file_content]
    num_length = 0
    for i, char in enumerate(list_content):
        num_length += 1
        if list_content[i - 1] == '\n':
            num_length = 0

        elif char == ' ':
            start_index = i - num_length
            for _ in range(num_length + 1):
                list_content.pop(start_index)

            list_content.insert(start_index, your_new_number)

    out_text = ''.join(list_content)

with open('file.txt', 'w+') as file:
    file.write(out_text)

可以将^{}模块与delimiter=" "一起使用:

from csv import reader

with open('file.txt', 'r') as file:
    csv_reader = reader(file, delimiter=" ")
    for row in csv_reader:
        row[0] = '??.??'
        print(row)

哪些输出

['??.??', '1:34', '2:49', '5:21', '29:98']
['??.??', '1:23', '2:82', '5:23', '29:45']
...

请注意,您的数字将是字符串。您可能需要将它们转换为浮点数:

floats = [float(item) for item in row]

如果需要将更改写入文件,可以类似地使用^{}。你知道吗

您可以使用以下方法来实现本文件:你知道吗

data = None
with open('file.txt', 'r') as file:
    data = file.read()

def process_line_item(x):
    index = x[0]
    line_str = x[1]
    new_first_value = [str(x[0])] # you can put here new value depending on line index
    return ' '.join(new_first_value + x[1].split(' ')[1:])

new_data = '\n'.join(list(map(process_line_item, enumerate(data.split('\n')))))

with open('new_file.txt', 'w') as file:
    file.write(new_data)

file.txt

12.32 1:34 2:49 5:21 29:98
13.53 1:23 2:82 5:23 29:45
51.92 1:23 2:54 5:54 29:63
12.42 1:34 2:43 5:32 29:32

new_file.txt

0 1:34 2:49 5:21 29:98
1 1:23 2:82 5:23 29:45
2 1:23 2:54 5:54 29:63
3 1:34 2:43 5:32 29:32

相关问题 更多 >