Skip to main content

Sort lists naturally

Project description

https://travis-ci.org/SethMMorton/natsort.svg?branch=3.4.1 https://coveralls.io/repos/SethMMorton/natsort/badge.png?branch=3.4.1

Natural sorting for python.

Quick Description

When you try to sort a list of strings that contain numbers, the normal python sort algorithm sorts lexicographically, so you might not get the results that you expect:

>>> a = ['a2', 'a9', 'a1', 'a4', 'a10']
>>> sorted(a)
['a1', 'a10', 'a2', 'a4', 'a9']

Notice that it has the order (‘1’, ‘10’, ‘2’) - this is because the list is being sorted in lexicographical order, which sorts numbers like you would letters (i.e. ‘b’, ‘ba’, ‘c’).

natsort provides a function natsorted that helps sort lists “naturally”, either as real numbers (i.e. signed/unsigned floats or ints), or as versions. Using natsorted is simple:

>>> from natsort import natsorted
>>> a = ['a2', 'a9', 'a1', 'a4', 'a10']
>>> natsorted(a)
['a1', 'a2', 'a4', 'a9', 'a10']

natsorted identifies real numbers anywhere in a string and sorts them naturally.

Sorting version numbers is just as easy with the versorted function:

>>> from natsort import versorted
>>> a = ['version-1.9', 'version-2.0', 'version-1.11', 'version-1.10']
>>> versorted(a)
['version-1.9', 'version-1.10', 'version-1.11', 'version-2.0']
>>> natsorted(a)  # natsorted tries to sort as signed floats, so it won't work
['version-2.0', 'version-1.9', 'version-1.11', 'version-1.10']

You can mix and match int, float, and str (or unicode) types when you sort:

>>> a = ['4.5', 6, 2.0, '5', 'a']
>>> natsorted(a)
[2.0, '4.5', '5', 6, 'a']
>>> # On Python 2, sorted(a) would return [2.0, 6, '4.5', '5', 'a']
>>> # On Python 3, sorted(a) would raise an "unorderable types" TypeError

The natsort algorithm does other fancy things like

  • recursively descend into lists of lists

  • sort file paths correctly

  • allow custom sorting keys

  • exposes a natsort_key generator to pass to list.sort

Please see the package documentation for more details, including examples and recipes.

Shell script

natsort comes with a shell script called natsort, or can also be called from the command line with python -m natsort. The command line script is only installed onto your PATH if you don’t install via a wheel. There is apparently a known bug with the wheel installation process that will not create entry points.

Requirements

natsort requires python version 2.6 or greater (this includes python 3.x). To run version 2.6, 3.0, or 3.1 the argparse module is required.

Optional Dependency

The most efficient sorting can occur if you install the fastnumbers package (it helps with the string to number conversions.) natsort will still run (efficiently) without the package, but if you need to squeeze out that extra juice it is recommended you include this as a dependency. natsort will not require (or check) that fastnumbers is installed.

Depreciation Notices

  • In natsort version 4.0.0, the natsort_key function will be removed from the public API. All future development should use natsort_keygen in preparation for this.

  • In natsort version 3.1.0, the shell script changed how it interpreted input; previously, all input was assumed to be a filepath, but as of 3.1.0 input is just treated as a string. For most cases the results are the same.

    • As of natsort version 3.4.0, a --path option has been added to force the shell script to interpret the input as filepaths.

Author

Seth M. Morton

History

These are the last three entries of the changelog. See the package documentation for the complete changelog.

08-12-2014 v. 3.4.1

  • ‘natsort’ will now use the ‘fastnumbers’ module if it is installed. This gives up to an extra 30% boost in speed over the previous performance enhancements.

  • Made documentation point to more ‘natsort’ resources, and also added a new example in the examples section.

07-19-2014 v. 3.4.0

  • Fixed a bug that caused user’s options to the ‘natsort_key’ to not be passed on to recursive calls of ‘natsort_key’.

  • Added a ‘natsort_keygen’ function that will generate a wrapped version of ‘natsort_key’ that is easier to call. ‘natsort_key’ is now set to depreciate at natsort version 4.0.0.

  • Added an ‘as_path’ option to ‘natsorted’ & co. that will try to treat input strings as filepaths. This will help yield correct results for OS-generated inputs like ['/p/q/o.x', '/p/q (1)/o.x', '/p/q (10)/o.x', '/p/q/o (1).x'].

  • Massive performance enhancements for string input (1.8x-2.0x), at the expense of reduction in speed for numeric input (~2.0x).

    • This is a good compromise because the most common input will be strings, not numbers, and sorting numbers still only takes 0.6x the time of sorting strings. If you are sorting only numbers, you would use ‘sorted’ anyway.

  • Added the ‘order_by_index’ function to help in using the output of ‘index_natsorted’ and ‘index_versorted’.

  • Added the ‘reverse’ option to ‘natsorted’ & co. to make it’s API more similar to the builtin ‘sorted’.

  • Added more unit tests.

  • Added auxiliary test code that helps in profiling and stress-testing.

  • Reworked the documentation, moving most of it to PyPI’s hosting platform.

  • Added support for coveralls.io.

  • Entire codebase is now PyFlakes and PEP8 compliant.

06-28-2014 v. 3.3.0

  • Added a ‘versorted’ method for more convenient sorting of versions.

  • Updated command-line tool –number_type option with ‘version’ and ‘ver’ to make it more clear how to sort version numbers.

  • Moved unit-testing mechanism from being docstring-based to actual unit tests in actual functions.

    • This has provided the ability determine the coverage of the unit tests (99%).

    • This also makes the pydoc documentation a bit more clear.

  • Made docstrings for public functions mirror the README API.

  • Connected natsort development to Travis-CI to help ensure quality releases.

Project details


Download files

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

Source Distributions

natsort-3.4.1.zip (51.6 kB view details)

Uploaded Source

natsort-3.4.1.tar.gz (36.3 kB view details)

Uploaded Source

Built Distribution

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

natsort-3.4.1-py2.py3-none-any.whl (18.9 kB view details)

Uploaded Python 2Python 3

File details

Details for the file natsort-3.4.1.zip.

File metadata

  • Download URL: natsort-3.4.1.zip
  • Upload date:
  • Size: 51.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for natsort-3.4.1.zip
Algorithm Hash digest
SHA256 08fbf0c2b9eb033f71996919ea2063f0b64fb9389e76603284666c1058347df0
MD5 a938c7912e5b028f53474d94d1229b54
BLAKE2b-256 90724d5abf57cb89d88191ce827e14f1deba593dcd146f5851d9853caa020986

See more details on using hashes here.

File details

Details for the file natsort-3.4.1.tar.gz.

File metadata

  • Download URL: natsort-3.4.1.tar.gz
  • Upload date:
  • Size: 36.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for natsort-3.4.1.tar.gz
Algorithm Hash digest
SHA256 318b8673604e407009123c9da77372399b5032486c35ccaa8b2d1bd095c57501
MD5 ee001366c90a1d814797150f5983f158
BLAKE2b-256 8bcaee72a021c85824bbd8ab70a2b3128bfb209596da096a6a4230fcdc3aaf52

See more details on using hashes here.

File details

Details for the file natsort-3.4.1-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for natsort-3.4.1-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 057dbebdd41910760b7fbfb960b8343ae6d6b34f68ffbcf3f5c7fc2a86c20312
MD5 36a0f0ab324048a61b6f0930308358f4
BLAKE2b-256 c280a279c9b6f35f749a2d4487e500849c3dd284e462a1b5046f300e6c791567

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