3

我有一个文件,其中包含条目列表,日期包含“Jan”、“Feb”、“Mar”等。

我想

569207,ngph,RUN,512,16, 2012-Jan-23 01:42 ,2012-04-23 10:53

成为

569207,ngph,RUN,512,16, 2012-01-23 01:42 ,2012-04-23 10:53。

我写了以下内容:

   for line in f:
        if re.search(r'Jan', line):
            f1.write(line.replace('Jan', '01'))
        elif re.search(r'Feb', line):
            f1.write(line.replace('Feb', '02'))
        elif re.search(r'Mar', line):
            f1.write(line.replace('Mar', '03'))
        elif re.search(r'Apr', line):
            f1.write(line.replace('Apr', '04'))
        elif re.search(r'May', line):
            f1.write(line.replace('May', '05'))
        elif re.search(r'Jun', line):
            f1.write(line.replace('Jun', '06'))
        elif re.search(r'Jul', line):
            f1.write(line.replace('Jul', '07'))
        elif re.search(r'Aug', line):
            f1.write(line.replace('Aug', '08'))
        elif re.search(r'Sep', line):
            f1.write(line.replace('Sep', '09'))
        elif re.search(r'Oct', line):
            f1.write(line.replace('Oct', '10'))
        elif re.search(r'Nov', line):
            f1.write(line.replace('Nov', '11'))
        elif re.search(r'Dec', line):
            f1.write(line.replace('Dec', '12'))

哪个有效,但有更清洁的方法吗?我希望它遍历大约 100 行的整个文件并自动将月份更改为数字。谢谢。

4

3 回答 3

12

两种可能:

  1. 日期时间模块
  2. 像你一样的DIY解决方案

python 文档值得一读,您可能会找到一种更简单的方法来做更多的事情,而不仅仅是回答这个问题。

至于 DIY 解决方案,您似乎有很多重复代码,并且不需要正则表达式。你可以做

for i, month in enumerate(months,1): 
    line.replace(month, str(i))

months月份列表在哪里。

于 2012-04-23T10:14:50.573 回答
10

datetime 是答案,例如:

>>> import datetime
>>> datetime.datetime.strptime('Mar 2013',"%b %Y")
datetime.datetime(2013, 3, 1, 0, 0)

在http://docs.python.org/2/library/datetime.html检查格式指令

于 2013-05-14T10:22:17.847 回答
3

你也可以使用字典:

month_numbers = {'-Jan-': '-01-', '-Feb-': '-02-', ...}
for k, v in month_numbers.items():
    line = line.replace(k, v)
print(line)

您可以使用正则表达式,您可以使用简单的字符串replace()方法,而无需先检查月份名称是否在字符串中。我不知道字符串是否Jan可以在输入字符串的其他部分,但 IMO 替换-Jan--01-.

于 2012-04-23T10:29:54.757 回答