2021-08-11 23:59:29 -04:00
|
|
|
:mod:`sys` -- system specific functions
|
|
|
|
=======================================
|
2014-10-30 21:37:19 -04:00
|
|
|
|
2021-08-11 23:59:29 -04:00
|
|
|
.. module:: sys
|
2014-10-30 21:37:19 -04:00
|
|
|
:synopsis: system specific functions
|
|
|
|
|
2017-07-02 08:37:31 -04:00
|
|
|
|see_cpython_module| :mod:`python:sys`.
|
|
|
|
|
2014-10-30 21:37:19 -04:00
|
|
|
Functions
|
|
|
|
---------
|
|
|
|
|
2020-01-11 01:44:17 -05:00
|
|
|
.. function:: exit(retval=0, /)
|
2014-10-30 21:37:19 -04:00
|
|
|
|
2016-05-01 06:42:36 -04:00
|
|
|
Terminate current program with a given exit code. Underlyingly, this
|
2017-06-27 17:37:47 -04:00
|
|
|
function raise as `SystemExit` exception. If an argument is given, its
|
|
|
|
value given as an argument to `SystemExit`.
|
2014-10-30 21:37:19 -04:00
|
|
|
|
2019-08-15 03:42:38 -04:00
|
|
|
.. function:: atexit(func)
|
|
|
|
|
|
|
|
Register *func* to be called upon termination. *func* must be a callable
|
|
|
|
that takes no arguments, or ``None`` to disable the call. The ``atexit``
|
|
|
|
function will return the previous value set by this function, which is
|
|
|
|
initially ``None``.
|
|
|
|
|
|
|
|
.. admonition:: Difference to CPython
|
|
|
|
:class: attention
|
|
|
|
|
|
|
|
This function is a MicroPython extension intended to provide similar
|
|
|
|
functionality to the :mod:`atexit` module in CPython.
|
|
|
|
|
2021-08-11 23:59:29 -04:00
|
|
|
.. function:: print_exception(exc, file=sys.stdout, /)
|
2014-12-06 17:18:37 -05:00
|
|
|
|
2017-06-27 17:37:47 -04:00
|
|
|
Print exception with a traceback to a file-like object *file* (or
|
2021-08-11 23:59:29 -04:00
|
|
|
`sys.stdout` by default).
|
2014-12-06 17:18:37 -05:00
|
|
|
|
2014-12-19 17:10:38 -05:00
|
|
|
.. admonition:: Difference to CPython
|
2014-12-22 08:42:30 -05:00
|
|
|
:class: attention
|
2014-12-19 17:10:38 -05:00
|
|
|
|
2016-06-10 16:06:56 -04:00
|
|
|
This is simplified version of a function which appears in the
|
|
|
|
``traceback`` module in CPython. Unlike ``traceback.print_exception()``,
|
|
|
|
this function takes just exception value instead of exception type,
|
2017-06-27 17:37:47 -04:00
|
|
|
exception value, and traceback object; *file* argument should be
|
2016-06-18 12:05:50 -04:00
|
|
|
positional; further arguments are not supported. CPython-compatible
|
2017-08-22 02:33:31 -04:00
|
|
|
``traceback`` module can be found in `micropython-lib`.
|
2014-12-19 17:10:38 -05:00
|
|
|
|
2021-11-12 10:09:56 -05:00
|
|
|
.. function:: settrace(tracefunc)
|
|
|
|
|
|
|
|
Enable tracing of bytecode execution. For details see the `CPython
|
2023-03-07 22:10:02 -05:00
|
|
|
documentation <https://docs.python.org/3/library/sys.html#sys.settrace>`_.
|
2021-11-12 10:09:56 -05:00
|
|
|
|
|
|
|
This function requires a custom MicroPython build as it is typically not
|
|
|
|
present in pre-built firmware (due to it affecting performance). The relevant
|
|
|
|
configuration option is *MICROPY_PY_SYS_SETTRACE*.
|
|
|
|
|
2014-10-30 21:37:19 -04:00
|
|
|
Constants
|
|
|
|
---------
|
|
|
|
|
|
|
|
.. data:: argv
|
|
|
|
|
2016-05-01 06:38:45 -04:00
|
|
|
A mutable list of arguments the current program was started with.
|
2014-10-30 21:37:19 -04:00
|
|
|
|
|
|
|
.. data:: byteorder
|
|
|
|
|
2017-06-27 17:37:47 -04:00
|
|
|
The byte order of the system (``"little"`` or ``"big"``).
|
2014-10-30 21:37:19 -04:00
|
|
|
|
2016-05-01 06:59:34 -04:00
|
|
|
.. data:: implementation
|
|
|
|
|
|
|
|
Object with information about the current Python implementation. For
|
|
|
|
MicroPython, it has following attributes:
|
|
|
|
|
2017-06-27 17:37:47 -04:00
|
|
|
* *name* - string "micropython"
|
|
|
|
* *version* - tuple (major, minor, micro), e.g. (1, 7, 0)
|
2022-04-26 03:28:39 -04:00
|
|
|
* *_machine* - string describing the underlying machine
|
2022-04-26 03:23:29 -04:00
|
|
|
* *_mpy* - supported mpy file-format version (optional attribute)
|
2016-05-01 06:59:34 -04:00
|
|
|
|
|
|
|
This object is the recommended way to distinguish MicroPython from other
|
|
|
|
Python implementations (note that it still may not exist in the very
|
|
|
|
minimal ports).
|
|
|
|
|
|
|
|
.. admonition:: Difference to CPython
|
|
|
|
:class: attention
|
|
|
|
|
|
|
|
CPython mandates more attributes for this object, but the actual useful
|
|
|
|
bare minimum is implemented in MicroPython.
|
|
|
|
|
2016-05-01 07:31:08 -04:00
|
|
|
.. data:: maxsize
|
|
|
|
|
|
|
|
Maximum value which a native integer type can hold on the current platform,
|
|
|
|
or maximum value representable by MicroPython integer type, if it's smaller
|
|
|
|
than platform max value (that is the case for MicroPython ports without
|
|
|
|
long int support).
|
|
|
|
|
|
|
|
This attribute is useful for detecting "bitness" of a platform (32-bit vs
|
|
|
|
64-bit, etc.). It's recommended to not compare this attribute to some
|
|
|
|
value directly, but instead count number of bits in it::
|
|
|
|
|
|
|
|
bits = 0
|
2021-08-11 23:59:29 -04:00
|
|
|
v = sys.maxsize
|
2016-05-01 07:31:08 -04:00
|
|
|
while v:
|
|
|
|
bits += 1
|
|
|
|
v >>= 1
|
|
|
|
if bits > 32:
|
|
|
|
# 64-bit (or more) platform
|
|
|
|
...
|
|
|
|
else:
|
|
|
|
# 32-bit (or less) platform
|
|
|
|
# Note that on 32-bit platform, value of bits may be less than 32
|
|
|
|
# (e.g. 31) due to peculiarities described above, so use "> 16",
|
|
|
|
# "> 32", "> 64" style of comparisons.
|
|
|
|
|
2016-05-01 06:32:15 -04:00
|
|
|
.. data:: modules
|
|
|
|
|
|
|
|
Dictionary of loaded modules. On some ports, it may not include builtin
|
|
|
|
modules.
|
|
|
|
|
2014-10-30 21:37:19 -04:00
|
|
|
.. data:: path
|
|
|
|
|
2016-05-01 06:38:45 -04:00
|
|
|
A mutable list of directories to search for imported modules.
|
2014-10-30 21:37:19 -04:00
|
|
|
|
2021-12-11 07:39:40 -05:00
|
|
|
.. admonition:: Difference to CPython
|
|
|
|
:class: attention
|
|
|
|
|
|
|
|
On MicroPython, an entry with the value ``".frozen"`` will indicate that import
|
|
|
|
should search :term:`frozen modules <frozen module>` at that point in the search.
|
|
|
|
If no frozen module is found then search will *not* look for a directory called
|
|
|
|
``.frozen``, instead it will continue with the next entry in ``sys.path``.
|
|
|
|
|
2014-10-30 21:37:19 -04:00
|
|
|
.. data:: platform
|
|
|
|
|
2016-05-01 07:39:38 -04:00
|
|
|
The platform that MicroPython is running on. For OS/RTOS ports, this is
|
|
|
|
usually an identifier of the OS, e.g. ``"linux"``. For baremetal ports it
|
2017-06-27 17:37:47 -04:00
|
|
|
is an identifier of a board, e.g. ``"pyboard"`` for the original MicroPython
|
2016-05-01 07:39:38 -04:00
|
|
|
reference board. It thus can be used to distinguish one board from another.
|
|
|
|
If you need to check whether your program runs on MicroPython (vs other
|
2021-08-11 23:59:29 -04:00
|
|
|
Python implementation), use `sys.implementation` instead.
|
2014-10-30 21:37:19 -04:00
|
|
|
|
2021-07-26 10:43:35 -04:00
|
|
|
.. data:: ps1
|
|
|
|
ps2
|
|
|
|
|
|
|
|
Mutable attributes holding strings, which are used for the REPL prompt. The defaults
|
|
|
|
give the standard Python prompt of ``>>>`` and ``...``.
|
|
|
|
|
2014-10-30 21:37:19 -04:00
|
|
|
.. data:: stderr
|
|
|
|
|
2017-12-04 11:36:20 -05:00
|
|
|
Standard error `stream`.
|
2014-10-30 21:37:19 -04:00
|
|
|
|
|
|
|
.. data:: stdin
|
|
|
|
|
2017-12-04 11:36:20 -05:00
|
|
|
Standard input `stream`.
|
2014-10-30 21:37:19 -04:00
|
|
|
|
|
|
|
.. data:: stdout
|
|
|
|
|
2017-12-04 11:36:20 -05:00
|
|
|
Standard output `stream`.
|
2014-10-30 21:37:19 -04:00
|
|
|
|
2021-07-26 10:41:27 -04:00
|
|
|
.. data:: tracebacklimit
|
|
|
|
|
|
|
|
A mutable attribute holding an integer value which is the maximum number of traceback
|
|
|
|
entries to store in an exception. Set to 0 to disable adding tracebacks. Defaults
|
|
|
|
to 1000.
|
|
|
|
|
|
|
|
Note: this is not available on all ports.
|
|
|
|
|
2014-10-30 21:37:19 -04:00
|
|
|
.. data:: version
|
|
|
|
|
2016-05-01 06:38:45 -04:00
|
|
|
Python language version that this implementation conforms to, as a string.
|
2014-10-30 21:37:19 -04:00
|
|
|
|
|
|
|
.. data:: version_info
|
|
|
|
|
2016-05-01 06:38:45 -04:00
|
|
|
Python language version that this implementation conforms to, as a tuple of ints.
|
2019-08-06 02:18:07 -04:00
|
|
|
|
|
|
|
.. admonition:: Difference to CPython
|
|
|
|
:class: attention
|
|
|
|
|
|
|
|
Only the first three version numbers (major, minor, micro) are supported and
|
|
|
|
they can be referenced only by index, not by name.
|