Pynotify搞砸日期时间,为什么?

Eri*_*icR 6 python pynotify importerror python-2.7

问题

这段代码

#!/usr/bin/env python
import pynotify
import time
import datetime

c='5/1/12 1:15 PM'
print c
dt = time.strptime(c, "%d/%m/%y %H:%M %p")
Run Code Online (Sandbox Code Playgroud)

产生

5/1/12 1:15 PM
Traceback (most recent call last):
  File "tmp.py", line 9, in <module>
    dt = time.strptime(c, "%d/%m/%y %H:%M %p")
  File "/usr/lib/python2.7/_strptime.py", line 454, in _strptime_time
    return _strptime(data_string, format)[0]
  File "/usr/lib/python2.7/_strptime.py", line 328, in _strptime
    data_string[found.end():])
ValueError: unconverted data remains: PM
Run Code Online (Sandbox Code Playgroud)

删除import pynotify,

#!/usr/bin/env python
import time
import datetime

c='5/1/12 1:15 PM'
print c
dt = time.strptime(c, "%d/%m/%y %H:%M %p")
Run Code Online (Sandbox Code Playgroud)

删除错误.

5/1/12 1:15 PM
Run Code Online (Sandbox Code Playgroud)

为什么?!!?!

Python版本

Linux2上的Python 2.7.2+(默认,2011年10月4日,20:06:09)[GCC 4.6.1]

pynotify.文件

我为pynotify.__file__和添加了打印调用datetime.__file__

/usr/lib/python2.7/lib-dynload/datetime.so
/usr/lib/python2.7/dist-packages/gtk-2.0/pynotify/__init__.pyc
5/1/12 1:15 PM
Traceback (most recent call last):
  File "a.py", line 11, in <module>
    dt = time.strptime(c, "%d/%m/%y %H:%M %p")
  File "/usr/lib/python2.7/_strptime.py", line 454, in _strptime_time
    return _strptime(data_string, format)[0]
  File "/usr/lib/python2.7/_strptime.py", line 328, in _strptime
    data_string[found.end():])
ValueError: unconverted data remains: PM
Run Code Online (Sandbox Code Playgroud)

PDB

5/1/12 1:15 PM
> /usr/lib/python2.7/_strptime.py(324)_strptime()
-> found = format_regex.match(data_string)
(Pdb) format
'%d/%m/%y %H:%M %p'
(Pdb) continue
> /usr/lib/python2.7/_strptime.py(329)_strptime()
-> if len(data_string) != found.end():
(Pdb) continue
> /usr/lib/python2.7/_strptime.py(331)_strptime()
-> raise ValueError("unconverted data remains: %s" %
(Pdb) len(data_string)
14
(Pdb) found.end()
12
(Pdb) found.group(0)
'5/1/12 1:15 '
Run Code Online (Sandbox Code Playgroud)

似乎'%d/%m/%y %H:%M %p'没有抓住所有'5/1/12 1:15 PM'

Jos*_*sad 3

这是一个有趣的问题。我敢打赌发生的事情是 pynotify 正在更改您的区域设置,这破坏了strptime对时间戳字符串的解释。

这是您的代码,其中包含一些调试打印语句,它们将说明该理论:

#!/usr/bin/env python

import time
import datetime
import locale

print locale.getlocale()
import pynotify
print locale.getlocale()
c='5/1/12 1:15 PM'
print c
dt = time.strptime(c, "%d/%m/%y %H:%M %p")
Run Code Online (Sandbox Code Playgroud)

在我的系统上,我得到以下信息:

(None, None)
('en_US', 'UTF8')
5/1/12 1:15 PM
Run Code Online (Sandbox Code Playgroud)

我没有收到你的错误,但 pynotify 可能将你的区域设置设置为完全愚蠢的东西,这使 strptime 感到困惑。

也许看看它并稍微调整一下你的语言环境设置,要么在调用 strptime 之前取消设置(然后在调用 strptime 之后将其设置回来,不知道 pynotify 会做出什么样的假设),或者如果你发现它设置为某个值,则将其设置为正常的值愚蠢的。