Skip to main content

A collection of core functions for tool script writing

Project description

cjnfuncs - A framework and collection of utility functions for script writing

cjnfuncs is comprised of several modules (follow links to respective documentation)

NOTE: Since relative links to other .md files do not work on PyPI, please go to the cjnfuncs GitHub repo to read the documentation.

module Description/Purpose
core Set up the base environment
configman Feature-rich configuration file toolset
timevalue Handle time values with units, such as '5m' (5 minutes), and schedule future operations
mungePath Ease-of-use pathlib extension for constructing and manipulating file paths
rwt / run_with_timeout Execute any function with an enforced timeout
deployfiles Push bundled setup files within a package to the proper user/system locations
resourcelock Inter-process resource lock mechanism
SMTP Send notification and email messages

Developed and tested on Python 3.9.21 and supported on all higher Python versions. Developed on Linux. Supported on Windows, except for the resourcelock module (posix-ipc module dependency).

In this documentation, "tool script" refers to a Python project that imports and uses cjnfuncs. Some may be simple scripts, and others may themselves be installed packages.


Installation and usage

pip install cjnfuncs

A package template using cjnfuncs is available at https://github.com/cjnaz/tool_template, which is the basis of PyPI posted tools such as:

Project repo: https://github.com/cjnaz/cjnfuncs


Key changes since the prior major public release (version 3.0)

  • Several issues with Windows support were fixed.

  • configman.config_item() now supports a safe_mode switch, which will speed up Windows usage of loadconfig() at some risk. See the note on config_item().

  • Named child loggers are now implemented on several cjnfuncs modules. By default, logging from cjnfuncs modules is disabled (logging events are usually at the INFO or DEBUG level, while the default logging level is set to WARNING). For example, logging from configman may be enabled by logging.getLogger('cjnfuncs.configman').setLevel(logging.INFO), or using core.set_logging.level(logging.INFO, 'cjnfuncs.configman').

  • Changed mungePath set_attributes from default True to default False to avoid long processing time on Windows by default.

  • deployfiles can now create an empty target directory.


Revision history

  • 3.1 251109 Support for and use of child loggers, deployfiles create empty dir, Windows fixes, config_item() safe_mode switch, mungePath set_attributes from default False
  • 3.0.1 251005 - Allow '.' in config section names
  • 3.0 250705 - Added run_with_timeout, set / restore_logging_level, periodic_logging, get_next_dt. Functional change to mungePath.
  • 2.5 250206 - Added multi-line and quoted string support to configman
  • 2.4.1 241118 - resource_lock only init lock_info if not existing
  • 2.4 241105 - Twilio support in snd_notif, resource_lock trace/debug features, check_path_exists exception fix
  • 2.3 240821 - Added mungePath ./ support. Resolved check_path_exists() memory leak. Added same_process_ok to resourcelock.getlock() Added prereload_callback to config_item.loadconfig()
  • 2.2 240119 - Added SMTP DKIM support. Set SMTP server connect timeout to EmailRetryWait.
  • 2.1 240104 - Partitioned to separate modules. Added modify_configfile. Added native support for float, list, tuple, and dict in loadconfig(). Added getcfg() type checking. Documentation touch for logging formats in config file. Improved snd_notif failure logging. Added email/notif send retries. Added resourcelock module.
  • 2.0.1 230222 - deploy_files() fix for files from package
  • 2.0 230208 - Refactored and converted to installed package. Renamed funcs3 to cjnfuncs.
  • ...
  • 0.1 180524 - New. First github posting

Project details


Download files

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

Source Distribution

cjnfuncs-3.1.tar.gz (89.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

cjnfuncs-3.1-py3-none-any.whl (47.7 kB view details)

Uploaded Python 3

File details

Details for the file cjnfuncs-3.1.tar.gz.

File metadata

  • Download URL: cjnfuncs-3.1.tar.gz
  • Upload date:
  • Size: 89.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.9

File hashes

Hashes for cjnfuncs-3.1.tar.gz
Algorithm Hash digest
SHA256 a22c97f975a1a6d20fe783301e7d1afc3738072286b266019480eb9c98942cdc
MD5 413217974d1786db6cfe3b0565f6cb91
BLAKE2b-256 e45ba8190c6f6d449ddbe0507655905a0b9e8284daaefab69a8a0f9ceef8f3b3

See more details on using hashes here.

File details

Details for the file cjnfuncs-3.1-py3-none-any.whl.

File metadata

  • Download URL: cjnfuncs-3.1-py3-none-any.whl
  • Upload date:
  • Size: 47.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.9

File hashes

Hashes for cjnfuncs-3.1-py3-none-any.whl
Algorithm Hash digest
SHA256 87ed094a9418e8de16b168807c2cd35bd2f9beeaf651b6bea4fa09a71c7b5b3d
MD5 7c9023d63ca34cac0a6fa38e93c28f82
BLAKE2b-256 df9507f8ea91495f29abdfebb64d5c98c684a9644feff5c52405e6b638c005aa

See more details on using hashes here.

Supported by

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