Version v1.1.9 as of 2023-08-08 see Changelog
some convenience functions for lists
automated tests, Github Actions, Documentation, Badges, etc. are managed with PizzaCutter (cookiecutter on steroids)
Python version required: 3.8.0 or newer
tested on recent linux with python 3.8, 3.9, 3.10, 3.11, 3.12-dev, pypy-3.9, pypy-3.10 - architectures: amd64
100% code coverage, flake8 style checking ,mypy static type checking ,tested under Linux, macOS, Windows, automatic daily builds and monitoring
- Try it Online
- Usage
- Usage from Commandline
- Installation and Upgrade
- Requirements
- Acknowledgements
- Contribute
- Report Issues
- Pull Request
- Code of Conduct
- License
- Changelog
You might try it right away in Jupyter Notebook by using the "launch binder" badge, or click here
the library provides following functions:
def deduplicate(elements: List[Any]) -> List[Any]:
"""get deduplicated list, does NOT keep Order !
>>> deduplicate([])
[]
>>> sorted(deduplicate(['c','b','a']))
['a', 'b', 'c']
>>> sorted(deduplicate(['b','a','c','b','a']))
['a', 'b', 'c']
>>> sorted(deduplicate(['x','x','x','y','y']))
['x', 'y']
"""
def del_elements_containing(elements: List[str], search_string: str) -> List[str]:
""" delete the elements which contain (or are equal) the search_string
>>> del_elements_containing(['a', 'abba', 'c'], 'b')
['a', 'c']
>>> del_elements_containing(['a', 'abba', 'c'], 'z')
['a', 'abba', 'c']
>>> del_elements_containing(['a', 'abba', 'c'], '')
['a', 'abba', 'c']
>>> del_elements_containing([], 'b')
[]
"""
def filter_contains(elements: List[Any], search_string: str) -> List[str]:
"""Retrieve a list of string elements that contain the specified search string.
>>> filter_contains([], 'bc')
[]
>>> filter_contains(['abcd', 'def', 1, None], 'bc')
['abcd']
"""
def filter_fnmatch(elements: List[Any], search_pattern: str) -> List[str]:
"""Retrieve a list of string elements which are matching the fnmatch search pattern
>>> filter_fnmatch([], 'a*')
[]
>>> filter_fnmatch(['abc', 'def', 1, None], 'a*')
['abc']
"""
def is_element_containing(elements: List[str], search_string: str) -> bool:
"""delivers true, if one of the strings in the list contains (or is equal) the searchstring
>>> is_element_containing([], '')
False
>>> is_element_containing(['abcd', 'def', 1, None], '')
True
>>> is_element_containing(['abcd', 'def', 1, None], 'bc')
True
>>> is_element_containing(['abcd', 'def', 1, None], 'fg')
False
"""
def is_fnmatching(elements: List[Any], search_pattern: str) -> bool:
"""True if at least one element is matching the searchpattern
>>> is_fnmatching([], 'bc')
False
>>> is_fnmatching(['abcd', 'def', 1, None], '*bc*')
True
>>> is_fnmatching(['abcd', 'def', 1, None], '*1*')
False
"""
def is_fnmatching_one_pattern(elements: List[Any], search_patterns: List[str]) -> bool:
"""True if at least one element is matching at least one of the searchpatterns
>>> is_fnmatching_one_pattern([], [])
False
>>> is_fnmatching_one_pattern(['abcd', 'def', 1, None], [])
False
>>> is_fnmatching_one_pattern(['abcd', 'def', 1, None], ['*bc*', '*fg*'])
True
>>> is_fnmatching_one_pattern(['abcd', 'def', 1, None], ['*fg*', '*gh*'])
False
"""
def substract_all_keep_sorting(minuend: List[Any], subtrahend: List[Any]) -> List[Any]:
"""substract the list l_subtrahend from list l_minuend
if the same element is more than once in l_minuend, so all of that elements are subtracted.
the sorting order of the minuend is preserved
>>> substract_all_keep_sorting([], ['a'])
[]
>>> substract_all_keep_sorting(['a', 'a'], [])
['a', 'a']
>>> my_l_minuend = ['a','a','b']
>>> my_l_subtrahend = ['a','c']
>>> substract_all_keep_sorting(my_l_minuend, my_l_subtrahend)
['b']
"""
def substract_all_unsorted_fast(minuend: List[Any], subtrahend: List[Any]) -> List[Any]:
"""substract the list l_subtrahend from list l_minuend
if the same element is more than once in l_minuend, so all of that elements are subtracted.
the sorting order of the minuend is NOT preserved
>>> my_minuend = ['a','a','b']
>>> my_subtrahend = ['a','c']
>>> substract_all_unsorted_fast(my_minuend, my_subtrahend)
['b']
"""
Usage: lib_list [OPTIONS] COMMAND [ARGS]... some convenience functions for lists Options: --version Show the version and exit. --traceback / --no-traceback return traceback information on cli -h, --help Show this message and exit. Commands: info get program informations
- Before You start, its highly recommended to update pip and setup tools:
python -m pip --upgrade pip python -m pip --upgrade setuptools
- to install the latest release from PyPi via pip (recommended):
python -m pip install --upgrade lib_list
- to install the latest release from PyPi via pip, including test dependencies:
python -m pip install --upgrade lib_list[test]
- to install the latest version from github via pip:
python -m pip install --upgrade git+https://github.com/bitranox/lib_list.git
- include it into Your requirements.txt:
# Insert following line in Your requirements.txt: # for the latest Release on pypi: lib_list # for the latest development version : lib_list @ git+https://github.com/bitranox/lib_list.git # to install and upgrade all modules mentioned in requirements.txt: python -m pip install --upgrade -r /<path>/requirements.txt
- to install the latest development version, including test dependencies from source code:
# cd ~ $ git clone https://github.com/bitranox/lib_list.git $ cd lib_list python -m pip install -e .[test]
- via makefile: makefiles are a very convenient way to install. Here we can do much more, like installing virtual environments, clean caches and so on.
# from Your shell's homedirectory:
$ git clone https://github.com/bitranox/lib_list.git
$ cd lib_list
# to run the tests:
$ make test
# to install the package
$ make install
# to clean the package
$ make clean
# uninstall the package
$ make uninstall
following modules will be automatically installed :
## Project Requirements
click
cli_exit_tools
- special thanks to "uncle bob" Robert C. Martin, especially for his books on "clean code" and "clean architecture"
I would love for you to fork and send me pull request for this project. - please Contribute
This software is licensed under the MIT license
---
- new MAJOR version for incompatible API changes,
- new MINOR version for added functionality in a backwards compatible manner
- new PATCH version for backwards compatible bug fixes
- 2023-07-30:
- flake 8 E721 do not compare types, for instance checks use isinstance()
- 2023-07-14:
- add codeql badge
- move 3rd_party_stubs outside the src directory to
./.3rd_party_stubs
- add pypy 3.10 tests
- add python 3.12-dev tests
- 2023-07-13:
- require minimum python 3.8
- remove python 3.7 tests
- introduce PEP517 packaging standard
- introduce pyproject.toml build-system
- remove mypy.ini
- remove pytest.ini
- remove setup.cfg
- remove setup.py
- remove .bettercodehub.yml
- remove .travis.yml
- update black config
- clean ./tests/test_cli.py
2022-03-25: implement github actions
- 2020-10-09: service release
- update travis build matrix for linux 3.9-dev
- update travis build matrix (paths) for windows 3.9 / 3.10
- 2020-08-08: service release
- fix documentation
- fix travis
- deprecate pycodestyle
- implement flake8
2020-08-01: fix pypi deploy
2020-07-31: fix travis build
- 2020-07-29: feature release
- use the new pizzacutter template
- use cli_exit_tools
- 2020-07-16: feature release
- fix cli test
- enable traceback option on cli errors
- manage project with PizzaCutter
2019-09-03: Initial public release