使用文本文件中的正则表达式重新格式化日期时间值

时间:2016-09-30 08:13:47

标签: python regex datetime reformatting

我想使用正则表达式更改某些文本行中的时间格式。 我怎样才能使用旧的时间值? 我的代码到现在为止:

def file_replace_words(file_in, word_to_replace, replace_with):
    f = open(file_in, "r+")
    data = f.readlines()
    f.seek(0)
    for line in data:
        line = re.sub(word_to_replace, replace_with, line)
        f.write(line)
    f.truncate()
    f.close()

f.file_replace_words(path_putty_log, r"(\d\d\/\d\d\/\d\d) - \d\d:\d\d:\d\d:\d\d\d", 
                    "my time in format 31.12.1999 11:54:23")

我想将值从29/09/16 - 16:38:09:808更改为29.09.16 16:38:09。

1 个答案:

答案 0 :(得分:1)

您可以在正则表达式中添加一些捕获组,并使用具有相应反向引用的替换模式。

使用

r'(\d\d)/(\d\d)/(\d\d) - (\d\d:\d\d:\d\d):\d{3}'
  |- 1-| |- 2-| |-3 -|   | ----- 4 ---- |

并替换为r'\1.\2.\3 \4'

请参阅regex demo

注意:如果有更长的子字符串看起来像这些日期时间戳,您可能希望用字边界\b括起整个模式:r'\b(\d\d)/(\d\d)/(\d\d) - (\d\d:\d\d:\d\d):\d{3}\b'