8000 bpo-33400: Clarified documentation to indicate no strict adherence to… · python/cpython@c4994dc · GitHub
[go: up one dir, main page]

Skip to content

Commit c4994dc

Browse files
authored
bpo-33400: Clarified documentation to indicate no strict adherence to ISO 8601. (GH-6702)
1 parent 9d3627e commit c4994dc

File tree

4 files changed

+22
-20
lines changed

4 files changed

+22
-20
lines changed

Doc/howto/logging.rst

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -296,9 +296,9 @@ which should print something like this:
296296
297297
2010-12-12 11:41:42,612 is when this event was logged.
298298
299-
The default format for date/time display (shown above) is ISO8601. If you need
300-
more control over the formatting of the date/time, provide a *datefmt*
301-
argument to ``basicConfig``, as in this example::
299+
The default format for date/time display (shown above) is like ISO8601 or
300+
RFC 3339. If you need more control over the formatting of the date/time, provide
301+
a *datefmt* argument to ``basicConfig``, as in this example::
302302

303303
import logging
304304
logging.basicConfig(format='%(asctime)s %(message)s', datefmt='%m/%d/%Y %I:%M:%S %p')

Doc/library/logging.config.rst

Lines changed: 4 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -790,10 +790,10 @@ Sections which specify formatter configuration are typified by the following.
790790
791791
The ``format`` entry is the overall format string, and the ``datefmt`` entry is
792792
the :func:`strftime`\ -compatible date/time format string. If empty, the
793-
package substitutes ISO8601 format date/times, which is almost equivalent to
794-
specifying the date format string ``'%Y-%m-%d %H:%M:%S'``. The ISO8601 format
795-
also specifies milliseconds, which are appended to the result of using the above
796-
format string, with a comma separator. An example time in ISO8601 format is
793+
package substitutes ISO8601-style format date/times, which is almost equivalent to
794+
specifying the date format string ``'%Y-%m-%d %H:%M:%S'``. This format also
795+
specifies milliseconds, which are appended to the result of using the above
796+
format string, with a comma separator. An example time in this format is
797797
``2003-01-23 00:29:50,411``.
798798

799799
The ``class`` entry is optional. It indicates the name of the formatter's class

Doc/library/logging.rst

Lines changed: 6 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -515,8 +515,9 @@ The useful mapping keys in a :class:`LogRecord` are given in the section on
515515
Returns a new instance of the :class:`Formatter` class. The instance is
516516
initialized with a format string for the message as a whole, as well as a
517517
format string for the date/time portion of a message. If no *fmt* is
518-
specified, ``'%(message)s'`` is used. If no *datefmt* is specified, the
519-
ISO8601 date format is used.
518+
specified, ``'%(message)s'`` is used. If no *datefmt* is specified, an
519+
ISO8601-like (or RFC3339-like) date format is used. See the
520+
:meth:`formatTime` documentation for more details.
520521

521522
The *style* parameter can be one of '%', '{' or '$' and determines how
522523
the format string will be merged with its data: using one of %-formatting,
@@ -556,8 +557,8 @@ The useful mapping keys in a :class:`LogRecord` are given in the section on
556557
formatters to provide for any specific requirement, but the basic behavior
557558
is as follows: if *datefmt* (a string) is specified, it is used with
558559
:func:`time.strftime` to format the creation time of the
559-
record. Otherwise, the ISO8601 format is used. The resulting string is
560-
returned.
560+
record. Otherwise, an ISO8601-like (or RDC 3339-like) format is used. The
561+
resulting string is returned.
561562

562563
This function uses a user-configurable function to convert the creation
563564
time to a tuple. By default, :func:`time.localtime` is used; to change
@@ -568,7 +569,7 @@ The useful mapping keys in a :class:`LogRecord` are given in the section on
568569
attribute in the ``Formatter`` class.
569570

570571
.. versionchanged:: 3.3
571-
Previously, the default ISO 8601 format was hard-coded as in this
572+
Previously, the default ISO8601-like format was hard-coded as in this
572573
example: ``2010-09-06 22:38:15,292`` where the part before the comma is
573574
handled by a strptime format string (``'%Y-%m-%d %H:%M:%S'``), and the
574575
part after the comma is a millisecond value. Because strptime does not

Lib/logging/__init__.py

Lines changed: 9 additions & 8 deletions
Original file line numberDiff line numberDiff line change
@@ -466,7 +466,8 @@ def __init__(self, fmt=None, datefmt=None, style='%'):
466466
467467
Initialize the formatter either with the specified format string, or a
468468
default as described above. Allow for specialized date formatting with
469-
the optional datefmt argument (if omitted, you get the ISO8601 format).
469+
the optional datefmt argument. If datefmt is omitted, you get an
470+
ISO8601-like (or RFC 3339-like) format.
470471
471472
Use a style parameter of '%', '{' or '$' to specify that you want to
472473
use one of %-formatting, :meth:`str.format` (``{}``) formatting or
@@ -494,13 +495,13 @@ def formatTime(self, record, datefmt=None):
494495
in formatters to provide for any specific requirement, but the
495496
basic behaviour is as follows: if datefmt (a string) is specified,
496497
it is used with time.strftime() to format the creation time of the
497-
record. Otherwise, the ISO8601 format is used. The resulting
498-
string is returned. This function uses a user-configurable function
499-
to convert the creation time to a tuple. By default, time.localtime()
500-
is used; to change this for a particular formatter instance, set the
501-
'converter' attribute to a function with the same signature as
502-
time.localtime() or time.gmtime(). To change it for all formatters,
503-
for example if you want all logging times to be shown in GMT,
498+
record. Otherwise, an ISO8601-like (or RFC 3339-like) format is used.
499+
The resulting string is returned. This function uses a user-configurable
500+
function to convert the creation time to a tuple. By default,
501+
time.localtime() is used; to change this for a particular formatter
502+
instance, set the 'converter' attribute to a function with the same
503+
signature as time.localtime() or time.gmtime(). To change it for all
504+
formatters, for example if you want all logging times to be shown in GMT,
504505
set the 'converter' attribute in the Formatter class.
505506
"""
506507
ct = self.converter(record.created)

0 commit comments

Comments
 (0)
0