We can convert a string to datetime usingstrptime()function. This function is available indatetimeandtimemodules to parse a string to datetime and time objects respectively.
我们可以使用strptime()函数将字符串转换为datetime。datetime和time模块中提供了此功能,可分别将字符串解析为datetime和time对象。
Python strptime() is a class method in datetime class. Its syntax is:
Python strptime()是datetime类中的类方法。 其语法为:
datetime.strptime(date_string, format)
Both the arguments are mandatory and should be string. This function is exactly opposite ofstrftime() function, which converts datetime object to a string.
这两个参数都是强制性的,应为字符串。 此函数与strftime()函数完全相反,该函数将datetime对象转换为字符串。
We have the similar function available in time module too, where its syntax is:
我们在时间模块中也提供了类似的功能,其语法为:
time.strptime(time_string[, format])
Here the function returnsstruct_timeobject. If format string is not provided, it defaults to “%a %b %d %H:%M:%S %Y” which matches the formatting returned by ctime() function.
在这里,该函数返回struct_time对象。 如果未提供格式字符串,则默认为“%a%b%d%H:%M:%S%Y”,它与ctime()函数返回的格式匹配。
If the input string cannot be parsed according to the provided format, thenValueErroris raised. The exception message provides clear details about the issue in parsing.
如果无法根据提供的格式解析输入字符串,则引发ValueError。 异常消息提供了有关解析中问题的清晰详细信息。
Following table contains most of the commonly used format directives.
下表包含大多数常用的格式指令。
Directive | Description | Example Output |
---|---|---|
%a | Weekday as locale’s abbreviated name. | Sun, Mon, …, Sat (en_US) So, Mo, …, Sa (de_DE) |
%A | Weekday as locale’s full name. | Sunday, Monday, …, Saturday (en_US) Sonntag, Montag, …, Samstag (de_DE) |
%w | Weekday as a decimal number, where 0 is Sunday and 6 is Saturday. | 0, 1, 2, 3, 4, 5, 6 |
%d | Day of the month as a zero-padded decimal number. | 01, 02, …, 31 |
%b | Month as locale’s abbreviated name. | Jan, Feb, …, Dec (en_US) Jan, Feb, …, Dez (de_DE) |
%B | Month as locale’s full name. | January, February, …, December (en_US) Januar, Februar, …, Dezember (de_DE) |
%m | Month as a zero-padded decimal number. | 01, 02 … 12 |
%y | Year without century as a zero-padded decimal number. | 01, 02, … 99 |
%Y | Year with century as a decimal number. | 0001, 0002, … , 9999 |
%H | Hour (24-hour clock) as a zero-padded decimal number. | 01, 02, … , 23 |
%I | Hour (12-hour clock) as a zero-padded decimal number. | 01, 02, … , 12 |
%p | Locale’s equivalent of either AM or PM. | AM, PM (en_US) am, pm (de_DE) |
%M | Minute as a zero-padded decimal number. | 01, 02, … , 59 |
%S | Second as a zero-padded decimal number. | 01, 02, … , 59 |
%f | Microsecond as a decimal number, zero-padded on the left. | 000000, 000001, …, 999999 Not applicable with time module. |
%z | UTC offset in the form ±HHMM[SS] (empty string if the object is naive). | (empty), +0000, -0400, +1030 |
%Z | Time zone name (empty string if the object is naive). | (empty), UTC, IST, CST |
%j | Day of the year as a zero-padded decimal number. | 001, 002, …, 366 |
%U | Week number of the year (Sunday as the first day of the week) as a zero padded decimal number. All days in a new year preceding the first Sunday are considered to be in week 0. |
00, 01, …, 53 |
%W | Week number of the year (Monday as the first day of the week) as a decimal number. All days in a new year preceding the first Monday are considered to be in week 0. |
00, 01, …, 53 |
%c | Locale’s appropriate date and time representation. | Tue Aug 16 21:30:00 1988 (en_US) Di 16 Aug 21:30:00 1988 (de_DE) |
%x | Locale’s appropriate date representation. | 08/16/88 (None) 08/16/1988 (en_US) 16.08.1988 (de_DE) |
%X | Locale’s appropriate time representation. | 21:30:00 (en_US) 21:30:00 (de_DE) |
%% | A literal ‘%’ character. | % |
指示 | 描述 | 示例输出 |
---|---|---|
%一个 | 工作日为语言环境的缩写名称。 | 周日,周一,…,周六(en_US) 因此,Mo,...,Sa(de_DE) |
%一个 | 工作日为语言环境的全名。 | 周日,周一,…,周六(zh_CN) 桑塔格,蒙塔格,…,萨姆斯塔格(de_DE) |
%w | 以十进制数表示的工作日,其中0是星期日,6是星期六。 | 0、1、2、3、4、5、6 |
%d | 月份中的一天,以零填充的十进制数字表示。 | 01,02,…,31 |
%b | 月作为语言环境的缩写名称。 | 一月,二月,…,十二月(en_US) 一月,二月,…,德兹(de_DE) |
%B | 月作为语言环境的全名。 | 一月,二月,…,十二月(zh_CN) Januar,Februar,...,Dezember(de_DE) |
%m | 以零填充的十进制数字表示的月份。 | 01,02…12 |
%y | 无世纪的年份,为零填充的十进制数字。 | 01,02,…99 |
%Y | 以世纪作为十进制数字的年份。 | 0001、0002,…,9999 |
%H | 小时(24小时制),为补零的十进制数字。 | 01,02,…,23 |
%一世 | 小时(12小时制),为零填充的十进制数字。 | 01,02,…,12 |
%p | 相当于AM或PM的语言环境。 | 上午,下午(en_US) 上午,下午(de_DE) |
%M | 分钟,为零填充的十进制数字。 | 01,02,…,59 |
%S | 第二个为零填充的十进制数。 | 01,02,…,59 |
%F | 微秒,十进制数,在左侧补零。 | 000000,000001,…,999999 不适用于时间模块。 |
%z | UTC偏移量,格式为±HHMM [SS](如果对象是天真对象,则为空字符串)。 | (空),+ 0000,-0400,+ 1030 |
%Z | 时区名称(如果对象是天真对象,则为空字符串)。 | (空),UTC,IST,CST |
%j | 一年中的一天,为零填充的十进制数字。 | 001,002,…,366 |
%U | 一年中的周号(星期日为一周的第一天),以零填充的十进制数表示。 新年中第一个星期日之前的所有天均视为第0周。 |
00,01,…,53 |
%W | 一年中的星期数(星期一为一周的第一天),以十进制数表示。 第一个星期一之前的新的一年中的所有天均视为在第0周。 |
00,01,…,53 |
%C | 语言环境的适当日期和时间表示。 | 星期二八月16 21:30:00 1988(zh_CN) Di 16 Aug 21:30:00 1988(de_DE) |
%X | 语言环境的适当日期表示形式。 | 88年8月16日(无) 1988年8月16日(zh_CN) 1988年8月16日(de_DE) |
%X | 语言环境的适当时间表示形式。 | 21:30:00(zh_CN) 21:30:00(de_DE) |
%% | 文字“%”字符。 | % |
Let’s look into some specific examples of strptime() function to convert string to datetime and time objects.
我们来看一些将字符串转换为日期时间和时间对象的strptime()函数的特定示例。
from datetime import datetime
datetime_str = '09/19/18 13:55:26'
datetime_object = datetime.strptime(datetime_str, '%m/%d/%y %H:%M:%S')
print(type(datetime_object))
print(datetime_object) # printed in default format
Output:
输出:
We can use date() function alongwith strptime() function to convert string todateobject.
我们可以使用date()函数和strptime()函数将字符串转换为date对象。
date_str = '09-19-2018'
date_object = datetime.strptime(date_str, '%m-%d-%Y').date()
print(type(date_object))
print(date_object) # printed in default formatting
Output:
输出:
We can use time() function alongwith strptime() function to convert string to time object.
我们可以使用time()函数和strptime()函数将字符串转换为时间对象。
time_str = '13::55::26'
time_object = datetime.strptime(time_str, '%H::%M::%S').time()
print(type(time_object))
print(time_object)
Output:
输出:
Let’s see some examples of using time module strptime() function.
我们来看一些使用时间模块strptime()函数的示例。
import time
time_obj = time.strptime(time_str, '%H::%M::%S')
print(type(time_obj))
print(time_obj)
# default formatting - "%a %b %d %H:%M:%S %Y"
print(time.strptime('Wed Sep 19 14:55:02 2018'))
Output:
输出:
We can usetry-exceptblock to catch parsing exception and perform corrective actions.
我们可以使用try-except块来捕获解析异常并执行纠正措施。
datetime_str = '09/19/18 13:55:26'
try:
datetime_object = datetime.strptime(datetime_str, '%m/%d/%y')
except ValueError as ve:
print('ValueError Raised:', ve)
time_str = '99::55::26'
try:
time_object = time.strptime(time_str, '%H::%M::%S')
except ValueError as e:
print('ValueError:', e)
Output:
输出:
Notice that the ValueError message clearly explains the root cause of the parsing exception.
请注意,ValueError消息清楚地解释了解析异常的根本原因。
Let’s look at an example where a locale-specific string will be converted to datetime object. We will use locale module to set the locale to be used by python.
让我们看一个示例,其中将特定于语言环境的字符串转换为datetime对象。 我们将使用语言环境模块来设置要由python使用的语言环境。
import locale
locale.setlocale(locale.LC_ALL, 'de_DE')
date_str_de_DE = '10-Dezember-2018 Montag' # de_DE locale
datetime_object = datetime.strptime(date_str_de_DE, '%d-%B-%Y %A')
print(datetime_object)
Output:2018-12-10 00:00:00
输出:2018-12-10 00:00:00