session-info


Namesession-info JSON
Version 1.0.0 PyPI version JSON
download
home_pagehttps://gitlab.com/joelostblom/session_info
Summarysession_info outputs version information for modules loaded in the current session, Python, and the OS.
upload_time2021-05-06 17:24:56
maintainer
docs_urlNone
authorJoel Ostblom
requires_python>=3.6
licenseBSD-3
keywords
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            # session_info

`session_info` outputs version information for modules loaded in the current session,
Python, the OS, and the CPU. It is designed as a minimum measure to increase
reproducibility and provides similar information as `sessionInfo` and
`devtools::session_info` in R.

## Motivation

`session_info` is particularly useful when conducting exploratory data analysis in
Jupyter notebooks. Listing the version numbers of all loaded modules after
importing them is a simple way to ensure a minimum level of reproducibility
while requiring little additional effort. This practice is useful both when
revisiting notebooks and when sharing them with colleagues. `session_info` is meant to
complement more robust practices such as frozen virtual environments,
containers, and binder.

## Installation

`session_info` can be installed via `pip install session_info`. It does not depend on a package
manager to find version numbers since it fetches them from the module's version
string. Its only dependency is `stdlib_list`, which is used to distinguish
between standard library and third party modules.

## Usage

`session_info` can be used from a script like so:

```python
import math

import natsort
import pandas
import session_info


session_info.show()
```


Output:

```
Session information:
-----
natsort             7.1.1
pandas              1.2.2
session_info        1.0.0
-----
IPython             7.23.0
jupyter_client      6.1.12
jupyter_core        4.7.1
-----
Python 3.9.2 | packaged by conda-forge | (default, Feb 21 2021, 05:02:46) [GCC 9.3.0]
Linux-5.11.13-arch1-1-x86_64-with-glibc2.33
-----
Session information updated at 2021-05-06 09:59
```

The default behavior is to only output modules not in the standard library,
which is why the `math` module is omitted above (it can be included by
specifying `std_lib=True`). To include not only the explicitly imported
modules, but also any dependencies they import internally, specify `dependencies=True`.

When `session_info` is invoked from a Jupyter Notebook,
the output is concealed in `<details>` tags
and will only show when clicked.
Since this saves visual real estate,
any modules imported indirectly as dependencies
will be included by default
and it looks like this:

<details>
<summary>Click to view session information</summary>
<pre>
-----
natsort             7.1.1
pandas              1.2.2
session_info        1.0.0
-----
</pre>
<details>
<summary>Click to view modules imported as dependencies</summary>
<pre>
backcall            0.2.0
cython_runtime      NA
dateutil            2.8.1
decorator           5.0.7
ipykernel           5.5.3
ipython_genutils    0.2.0
jedi                0.18.0
numpy               1.20.2
parso               0.8.2
pexpect             4.8.0
pickleshare         0.7.5
prompt_toolkit      3.0.18
ptyprocess          0.7.0
pygments            2.8.1
pytz                2021.1
six                 1.15.0
storemagic          NA
tornado             6.1
traitlets           5.0.5
wcwidth             0.2.5
zmq                 22.0.3
</pre>
</details>
<pre>
-----
IPython             7.23.0
jupyter_client      6.1.12
jupyter_core        4.7.1
-----
Python 3.9.2 | packaged by conda-forge | (default, Feb 21 2021, 05:02:46) [GCC 9.3.0]
Linux-5.11.13-arch1-1-x86_64-with-glibc2.33
-----
Session information updated at 2021-05-06 09:59
</pre>
</details>

If you prefer to show the session information without the HTML tags,
you can use `session_info.show(html=False)` in the notebook
to get the same output as in the first example above.

`session_info` can also write the module dependencies
to a `requirements.txt` file,
which is compatible with `pip install -r /path/to/requirements.txt`.

[View the docstring for complete parameter information](https://gitlab.com/joelostblom/session_info/-/blob/master/sinfo/main.py#L73-118).

## Background

`session_info` started as minor modifications of `py_session`, and as it grew it
became convenient to create a new package. `session_info` was built with the help of
information provided in stackoverflow answers and existing similar packages,
including

- https://github.com/fbrundu/py_session
- https://github.com/jrjohansson/version_information
- https://github.com/rasbt/watermark
- https://stackoverflow.com/a/4858123/2166823
- https://stackoverflow.com/a/40690954/2166823
- https://stackoverflow.com/a/52187331/2166823
            

Raw data

            {
    "_id": null,
    "home_page": "https://gitlab.com/joelostblom/session_info",
    "name": "session-info",
    "maintainer": "",
    "docs_url": null,
    "requires_python": ">=3.6",
    "maintainer_email": "",
    "keywords": "",
    "author": "Joel Ostblom",
    "author_email": "joel.ostblom@protonmail.com",
    "download_url": "https://files.pythonhosted.org/packages/94/e4/ea615bb8185a298b21df1ac52a4a5db4e3351823a218f47ef3f883def88c/session_info-1.0.0.tar.gz",
    "platform": "",
    "description": "# session_info\n\n`session_info` outputs version information for modules loaded in the current session,\nPython, the OS, and the CPU. It is designed as a minimum measure to increase\nreproducibility and provides similar information as `sessionInfo` and\n`devtools::session_info` in R.\n\n## Motivation\n\n`session_info` is particularly useful when conducting exploratory data analysis in\nJupyter notebooks. Listing the version numbers of all loaded modules after\nimporting them is a simple way to ensure a minimum level of reproducibility\nwhile requiring little additional effort. This practice is useful both when\nrevisiting notebooks and when sharing them with colleagues. `session_info` is meant to\ncomplement more robust practices such as frozen virtual environments,\ncontainers, and binder.\n\n## Installation\n\n`session_info` can be installed via `pip install session_info`. It does not depend on a package\nmanager to find version numbers since it fetches them from the module's version\nstring. Its only dependency is `stdlib_list`, which is used to distinguish\nbetween standard library and third party modules.\n\n## Usage\n\n`session_info` can be used from a script like so:\n\n```python\nimport math\n\nimport natsort\nimport pandas\nimport session_info\n\n\nsession_info.show()\n```\n\n\nOutput:\n\n```\nSession information:\n-----\nnatsort             7.1.1\npandas              1.2.2\nsession_info        1.0.0\n-----\nIPython             7.23.0\njupyter_client      6.1.12\njupyter_core        4.7.1\n-----\nPython 3.9.2 | packaged by conda-forge | (default, Feb 21 2021, 05:02:46) [GCC 9.3.0]\nLinux-5.11.13-arch1-1-x86_64-with-glibc2.33\n-----\nSession information updated at 2021-05-06 09:59\n```\n\nThe default behavior is to only output modules not in the standard library,\nwhich is why the `math` module is omitted above (it can be included by\nspecifying `std_lib=True`). To include not only the explicitly imported\nmodules, but also any dependencies they import internally, specify `dependencies=True`.\n\nWhen `session_info` is invoked from a Jupyter Notebook,\nthe output is concealed in `<details>` tags\nand will only show when clicked.\nSince this saves visual real estate,\nany modules imported indirectly as dependencies\nwill be included by default\nand it looks like this:\n\n<details>\n<summary>Click to view session information</summary>\n<pre>\n-----\nnatsort             7.1.1\npandas              1.2.2\nsession_info        1.0.0\n-----\n</pre>\n<details>\n<summary>Click to view modules imported as dependencies</summary>\n<pre>\nbackcall            0.2.0\ncython_runtime      NA\ndateutil            2.8.1\ndecorator           5.0.7\nipykernel           5.5.3\nipython_genutils    0.2.0\njedi                0.18.0\nnumpy               1.20.2\nparso               0.8.2\npexpect             4.8.0\npickleshare         0.7.5\nprompt_toolkit      3.0.18\nptyprocess          0.7.0\npygments            2.8.1\npytz                2021.1\nsix                 1.15.0\nstoremagic          NA\ntornado             6.1\ntraitlets           5.0.5\nwcwidth             0.2.5\nzmq                 22.0.3\n</pre>\n</details>\n<pre>\n-----\nIPython             7.23.0\njupyter_client      6.1.12\njupyter_core        4.7.1\n-----\nPython 3.9.2 | packaged by conda-forge | (default, Feb 21 2021, 05:02:46) [GCC 9.3.0]\nLinux-5.11.13-arch1-1-x86_64-with-glibc2.33\n-----\nSession information updated at 2021-05-06 09:59\n</pre>\n</details>\n\nIf you prefer to show the session information without the HTML tags,\nyou can use `session_info.show(html=False)` in the notebook\nto get the same output as in the first example above.\n\n`session_info` can also write the module dependencies\nto a `requirements.txt` file,\nwhich is compatible with `pip install -r /path/to/requirements.txt`.\n\n[View the docstring for complete parameter information](https://gitlab.com/joelostblom/session_info/-/blob/master/sinfo/main.py#L73-118).\n\n## Background\n\n`session_info` started as minor modifications of `py_session`, and as it grew it\nbecame convenient to create a new package. `session_info` was built with the help of\ninformation provided in stackoverflow answers and existing similar packages,\nincluding\n\n- https://github.com/fbrundu/py_session\n- https://github.com/jrjohansson/version_information\n- https://github.com/rasbt/watermark\n- https://stackoverflow.com/a/4858123/2166823\n- https://stackoverflow.com/a/40690954/2166823\n- https://stackoverflow.com/a/52187331/2166823",
    "bugtrack_url": null,
    "license": "BSD-3",
    "summary": "session_info outputs version information for modules loaded in the current session, Python, and the OS.",
    "version": "1.0.0",
    "project_urls": {
        "Homepage": "https://gitlab.com/joelostblom/session_info"
    },
    "split_keywords": [],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "94e4ea615bb8185a298b21df1ac52a4a5db4e3351823a218f47ef3f883def88c",
                "md5": "5d6965233cacab00d22e6828f3eceafe",
                "sha256": "3cda5e03cca703f32ae2eadbd6bd80b6c21442cfb60e412c21cb8ad6d5cbb6b7"
            },
            "downloads": -1,
            "filename": "session_info-1.0.0.tar.gz",
            "has_sig": false,
            "md5_digest": "5d6965233cacab00d22e6828f3eceafe",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.6",
            "size": 24345,
            "upload_time": "2021-05-06T17:24:56",
            "upload_time_iso_8601": "2021-05-06T17:24:56.905655Z",
            "url": "https://files.pythonhosted.org/packages/94/e4/ea615bb8185a298b21df1ac52a4a5db4e3351823a218f47ef3f883def88c/session_info-1.0.0.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2021-05-06 17:24:56",
    "github": false,
    "gitlab": true,
    "bitbucket": false,
    "codeberg": false,
    "gitlab_user": "joelostblom",
    "gitlab_project": "session_info",
    "lcname": "session-info"
}
        
Elapsed time: 0.80339s