Skip to main content

Log and Flow tracking made easy with Python

Project description

lognflow

.. image:: https://img.shields.io/pypi/v/lognflow.svg :target: https://pypi.python.org/pypi/lognflow

.. image:: https://img.shields.io/travis/arsadri/lognflow.svg :target: https://travis-ci.com/arsadri/lognflow

.. image:: https://readthedocs.org/projects/lognflow/badge/?version=latest :target: https://lognflow.readthedocs.io/en/latest/?version=latest :alt: Documentation Status

Log and Flow tracking made easy with Python. You can install it by:

.. code-block:: python pip install lognflow

A simple program to use it would be similar to the following:

.. code-block:: python from lognflow import lognflow import numpy as np vec = np.random.rand(100)

logger = lognflow('c:\\test\\')
logger('This is a test for lognflow and log_var')
logger.log_single('vec', vec)

The logviewer is also very useful.

.. code-block:: python from lognflow import logviewer

logged = logviewer('c:\\test\\some_log\')
vec = logged.get_single('vec')

The printprogress makes a pretty nice progress bar.

.. code-block:: python from lognflow import printprogress

N = 100
pbar = printprogress(N)
for _ in range(N):
	# do_something()
	pbar()

In this package we use a folder on the HDD to generate files and folders in typical formats such as numpy npy and npz, png, ... to log. A log viewer is also availble to turn an already logged flow into variables. Obviously, it will read the folders and map them for you, which is something you could spend hours to do by yourself. Also there is the nicest progress bar, that you can easily understand and use or implement yourself when you have the time.

Looking at most logging packages online, you see that you need to spend a lot of time learning how to use them and realizing how they work. Especially when you have to deal with http servers and ... which will be a huge pain when working for companies who have their own HPC.

This is why lognflow is handy and straight forward.

Many tests are avialable in the tests directory.

Features

  • lognflow puts all the logs into a directory on your pc
  • lognflow makes it easy to log text or simple plots.
  • logviewer makes it easy to load variables or directories
  • printprogress is one of the best progress bars in Python.

Credits ^^^^^^^^

This package was created with Cookiecutter_ and the audreyr/cookiecutter-pypackage_ project template.

.. _Cookiecutter: https://github.com/audreyr/cookiecutter .. _audreyr/cookiecutter-pypackage: https://github.com/audreyr/cookiecutter-pypackage

History

0.1.0 (2022-11-16)

  • First release on PyPI.

0.3.0 (2022-12-19)

  • Very consistent and easy-to-handle interface

0.3.2 (2022-12-27)

  • log your dictionary.

0.5.2 (2023-01-11)

  • logger call takes txt only for the main_log
  • main_log name can have no time_stamp
  • All logs can be force_flush = True.
  • del is well implemented.

0.5.3 (2023-03-19)

  • use logger.log_single('aName', aDict) to save a dictionary using numpy.savez
  • time_in_file_name has been changed to time_tag, sorry there! but early stages.
  • time_tag is True in the constructor, but could always be set to False
  • All tests passed!

0.6.0 (2023-03-22)

  • This is a stable release
  • All text files are handled by the with statement
  • Renaming bug is fixed
  • all tests run properly.
  • lognflow has all that logviewer has. We will check if dir exists at every use

0.6.1 (2023-03-22)

  • rename had a bug that is fixed

0.6.2 (2023-03-25)

  • made it possible to flush_all()
  • We support Python 3.7+ because of dataclasses
  • printprogress now can disable printing anything and return ETA at the call

0.6.3 (2023-04-01)

  • lognflow class does all logviewer does. Maybe it is time to remove logviewer.

0.6.4 (2023-04-06)

  • Better documentation and examples for readme
  • get_var is added to lognflow to get buffered variables logged by log_var

0.6.5 (2023-04-26)

  • Fixed a bug in the docs to allow sphinx compile it.
  • log_var will log only the valid time stamps.
  • added end keyword argument to log_text

0.6.6 (2023-04-27)

  • Better documentation
  • added tifffile imread to logviewer and imwrite to lognflow

0.6.7 (2023-04-27)

  • A bug in tifffile support was fixed

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

lognflow-0.6.7.tar.gz (31.6 kB view details)

Uploaded Source

Built Distribution

lognflow-0.6.7-py2.py3-none-any.whl (24.6 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file lognflow-0.6.7.tar.gz.

File metadata

  • Download URL: lognflow-0.6.7.tar.gz
  • Upload date:
  • Size: 31.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.9.16

File hashes

Hashes for lognflow-0.6.7.tar.gz
Algorithm Hash digest
SHA256 ff7ab0a8b699558b91af20a0081bc701e168643dc822c9e57faeae7f4345aaf2
MD5 96809da98ce2d3330b1dbf1cbcdae3ba
BLAKE2b-256 15ee5eee0756f67df63c406470f42072ee6eff40f76a406196e0ce15e023acfa

See more details on using hashes here.

File details

Details for the file lognflow-0.6.7-py2.py3-none-any.whl.

File metadata

  • Download URL: lognflow-0.6.7-py2.py3-none-any.whl
  • Upload date:
  • Size: 24.6 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.9.16

File hashes

Hashes for lognflow-0.6.7-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 2850a0bf71329c9ffee3de23fe2891a187dd45ee48749aa3239952f7ea63c061
MD5 eed477a7be0ab6802f9ff2414ec5cc48
BLAKE2b-256 eccc479e29fcb0796c9d2f485cc67a9b83df721ec7418011c7c3f9c1e4503ddd

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page