python - 出现错误“ValueError:时间数据''与格式'%Y-%m-%d %H:%M:%S'不匹配”
问题描述
这是df的示例:
pId tPS tLL dZ
129 2019-12-02 15:04:09 2019-12-02 15:06:31 5f723
129 2019-12-02 15:04:15 2019-12-02 15:06:37 5f723
129 2019-12-02 15:05:15 2019-12-02 15:07:37 5f723
129 2019-12-02 15:05:18 2019-12-02 15:07:40 5f723
129 2019-12-02 15:05:24 2019-12-02 15:07:46 5f723
pID 是一个人的 ID,我正在尝试检查每个 ID 的进入、退出和持续时间。
这是代码:
from datetime import datetime
stats=df.sort_values(by=['pId', 'tPS', 'tLL'])[['pId', 'tPS', 'tLL', 'dZ']]
pid = ''
enter_t = ''
exit_t = ''
enter_exit_times=[]
for ind, row in stats.iterrows():
if pid =='':
enter_t = row['tPS']
print(enter_t)
if row['pId']!= pid or ((datetime.strftime(row['tLL'], "%Y-%m-%d %H:%M:%S")
- datetime.strftime(exit_t, "%Y-%m-%d %H:%M:%S")).total_seconds()>2*60*60):
duration = (datetime.strptime(exit_t, "%Y-%m-%d %H:%M:%S") -
datetime.strptime(enter_t, "%Y-%m-%d %H:%M:%S"))
enter_exit_times.append([pid, enter_t, exit_t, duration.total_seconds()])
pid = row['pId']
enter_t = row['tPS']
enter_exit_times.append([pid, enter_t, exit_t])
enter_exit_times_df = pd.DataFrame(enter_exit_times)
所以在这里
pid
是身份证enter_t
是进入时间exit_t
是退出时间tPS
是时候tLL
是时间。
然后我正在创建一个列表,我在下面编写一个循环。最初,我通过一个for
循环运行它,在该循环中迭代数据框的行。所以有两个if
循环,一个pid
是空值意味着它需要接受row[tPS]
,如果没有,那么它必须通过 not 循环。然后我计算持续时间,然后将值附加到进出时间。
我收到此错误:
2019-12-02 15:04:09
---------------------------------------------------------------------------
ValueError Traceback (most recent callast)
<ipython-input-411-fd8f6f998cc8> in <module>
12 if row['pId']!= pid or ((datetime.strftime(row['tLL'], "%Y-%m-%d %H:%M:%S")
13 - datetime.strftime(exit_t, "%Y-%m-%d %H:%M:%S")).total_seconds()>2*60*60):
---> 14 duration = (datetime.strptime(exit_t, "%Y-%m-%d %H:%M:%S") -
15 datetime.strptime(enter_t, "%Y-%m-%d %H:%M:%S"))
16 enter_exit_times.append([pid, enter_t, exit_t, duration.total_seconds()])
~/opt/anaconda3/lib/python3.7/_strptime.py in _strptime_datetime(cls, data_string, format)
575 """Return a class cls instance based on the input string and the
576 format string."""
--> 577 tt, fraction, gmtoff_fraction = _strptime(data_string, format)
578 tzname, gmtoff = tt[-2:]
579 args = tt[:6] + (fraction,)
~/opt/anaconda3/lib/python3.7/_strptime.py in _strptime(data_string, format)
357 if not found:
358 raise ValueError("time data %r does not match format %r" %
--> 359 (data_string, format))
360 if len(data_string) != found.end():
361 raise ValueError("unconverted data remains: %s" %
**ValueError: time data '' does not match format '%Y-%m-%d %H:%M:%S'**
解决方案
错误的原因exit_t
是未在循环中的任何位置设置。它是一个空字符串。您在循环之前将其设置为,exit_t = ''
但随后再也不会设置。这就是为什么strptime
在这里抛出错误:
>>> datetime.strptime(' ', "%Y-%m-%d %H:%M:%S")
Traceback (most recent call last):
...
File "/usr/local/Cellar/python/3.7.6/Frameworks/Python.framework/Versions/3.7/lib/python3.7/_strptime.py", line 359, in _strptime
(data_string, format))
ValueError: time data ' ' does not match format '%Y-%m-%d %H:%M:%S'
解决方案是简单地将其正确设置为"tLL"
(如果我理解正确的话)。
但我想更进一步地说,我认为你让代码比它应该的复杂得多。我的理解是,您只想计算"tPS"
(进入时间)和"tLL"
(退出时间)之间的持续时间。由于您已经在遍历每一行,因此您只需要适当地分配值
pid = row['pId']
enter_t_str = row['tPS'] # strings
exit_t_str = row['tLL'] # strings
然后使用将日期时间字符串转换为日期时间对象strptime
enter_t_dt = datetime.strptime(enter_t_str, "%Y-%m-%d %H:%M:%S")
exit_t_dt = datetime.strptime(exit_t_str, "%Y-%m-%d %H:%M:%S")
然后计算持续时间
duration = exit_t_dt - enter_t_dt
然后最后将其附加到您的列表中
enter_exit_times.append([pid, enter_t_str, exit_t_str, duration.total_seconds()])
无需跟踪"pId"
.
这是完整的代码:
stats = df.sort_values(by=['pId', 'tPS', 'tLL'])[['pId', 'tPS', 'tLL', 'dZ']]
pid = ''
enter_t = ''
exit_t = ''
enter_exit_times = []
for ind, row in stats.iterrows():
pid = row['pId']
enter_t_str = row['tPS']
exit_t_str = row['tLL']
enter_t_dt = datetime.strptime(enter_t_str, "%Y-%m-%d %H:%M:%S")
exit_t_dt = datetime.strptime(exit_t_str, "%Y-%m-%d %H:%M:%S")
duration = exit_t_dt - enter_t_dt
enter_exit_times.append([pid, enter_t_str, exit_t_str, duration.total_seconds()])
enter_exit_times_df = pd.DataFrame(enter_exit_times)
print(enter_exit_times_df)
和输出数据帧:
0 1 2 3
0 129 2019-12-02 15:04:09 2019-12-02 15:06:31 142.0
1 129 2019-12-02 15:04:15 2019-12-02 15:06:37 142.0
2 129 2019-12-02 15:05:15 2019-12-02 15:07:37 142.0
3 129 2019-12-02 15:05:18 2019-12-02 15:07:40 142.0
4 129 2019-12-02 15:05:24 2019-12-02 15:07:46 142.0
如果您只想获取一天中特定时间段的进入/退出时间,您可以创建datetime
开始时间和结束时间的对象,并进行定期比较:
>>> dt_beg = datetime(2019,12,2,8,0,0) #8AM
>>> dt_beg
datetime.datetime(2019, 12, 2, 8, 0)
>>> dt_end = datetime(2019,12,2,10,0,0) #10AM
>>> dt_end
datetime.datetime(2019, 12, 2, 10, 0)
>>> dt = datetime(2019,12,2,9,34,0) #9:34AM
>>> dt_beg < dt < dt_end
True
>>> dt = datetime(2019,12,2,14,34,0) #2:34PM
>>> dt_beg < dt < dt_end
False
因此,您可以添加一个过滤器来添加要附加到的内容enter_exit_times
:
if (enter_t_dt > start_dt and exit_t_dt < end_dt):
enter_exit_times.append(...)
推荐阅读
- alexa - Alexa 技能管理 - ASK CLI
- php - 是否有任何内置函数可以将不同语言的日期转换为 PHP 中的通用日期格式
- wpf - wpf 数据网格中当前可见的列
- magento2 - Magento 2 Uncaught TypeError: 传递给 __construct() 的参数 1 必须是 Magento\Backend\Block\Template\Context 的实例
- wordpress - WordPress 永久链接将类别名称添加到帖子网址
- ios - Swift - 在 Xib 中动态设置 UITableView 高度
- ios - 当 LynnBubbleTableView 框架中的内容增长时,如何移动到 tableview 的底部?
- python-3.x - Python OpenCV--电子邮件不发送从 OpenCV 保存的图像
- java - java 11中isEmpty()和isBlank()方法的区别
- python - 如何在python中将数据框从月中转换为月度时间序列?