Skip to main content

Sort lists naturally

Project description

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

Natural sorting for python.

Please see Deprecation Notices for an important backwards incompatibility notice for natsort version 4.0.0.

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 also perform locale-aware sorting (or “human sorting”), where the non-numeric characters are ordered based on their meaning, not on their ordinal value; this can be achieved with the humansorted function:

>>> a = ['Apple', 'Banana', 'apple', 'banana']
>>> natsorted(a)
['Apple', 'Banana', 'apple', 'banana']
>>> import locale
>>> locale.setlocale(locale.LC_ALL, 'en_US.UTF-8')
'en_US.UTF-8'
>>> from natsort import humansorted
>>> humansorted(a)
['apple', 'Apple', 'banana', 'Banana']

You may find you need to explicitly set the locale to get this to work (as shown in the example). Please see the following caveat and the Optional Dependencies section below before using the humansorted function, especially if you are on a BSD-based system (like Mac OS X).

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

  • control the case-sensitivity

  • 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.

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 Dependencies

fastnumbers

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 at installation.

PyICU

On BSD-based systems (this includes Mac OS X), the underlying locale library can be buggy (please see http://bugs.python.org/issue23195), so natsort will use PyICU under the hood if it is installed on your computer; this will give more reliable cross-platform results. natsort will not require (or check) that PyICU is installed at installation since in Linux-based systems and Windows systems locale should work just fine. Please visit https://github.com/SethMMorton/natsort/issues/21 for more details and how to install on Mac OS X.

Deprecation Notices

  • The default sorting algorithm for natsort will change in version 4.0.0 from signed floats (with exponents) to unsigned integers. The motivation for this change is that it will cause natsort to return results that pass the “least astonishment” test for the most common use case, which is sorting version numbers. If you currently rely on the default behavior to be signed floats, it is recommend that you add alg=ns.F to your natsort calls.

  • In natsort version 4.0.0, the number_type, signed, exp, as_path, and py3_safe options will be removed from the (documented) API, in favor of the alg option and ns enum. They will remain as keyword-only arguments after that (for the foreseeable future).

  • 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.

Author

Seth M. Morton

History

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

03-26-2015 v. 3.5.3

  • Fixed bug where --reverse-filter option in shell script was not getting checked for correctness.

  • Documentation updates to better describe locale bug, and illustrate upcoming default behavior change.

  • Internal improvements, including making test suite more granular.

01-13-2015 v. 3.5.2

  • Enhancement that will convert a ‘pathlib.Path’ object to a ‘str’ if ‘ns.PATH’ is enabled.

09-25-2014 v. 3.5.1

  • Fixed bug that caused list/tuples to fail when using ‘ns.LOWECASEFIRST’ or ‘ns.IGNORECASE’.

  • Refactored modules so that only the public API was in natsort.py and ns_enum.py.

  • Refactored all import statements to be absolute, not relative.

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.5.3.zip (62.1 kB view details)

Uploaded Source

natsort-3.5.3.tar.gz (43.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.5.3-py2.py3-none-any.whl (25.3 kB view details)

Uploaded Python 2Python 3

File details

Details for the file natsort-3.5.3.zip.

File metadata

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

File hashes

Hashes for natsort-3.5.3.zip
Algorithm Hash digest
SHA256 31c3fef3940ea6ea320eb9cbe02f3a717dbe3476cad02cdab5a071517bf5689d
MD5 1f4cb5643716da14b1f3e252eb8d0c0a
BLAKE2b-256 502b9dce443bff045672578fa9f9b377eda2f3b46d7f852b6c05c03c817ce741

See more details on using hashes here.

File details

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

File metadata

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

File hashes

Hashes for natsort-3.5.3.tar.gz
Algorithm Hash digest
SHA256 7b19864492acc05b7ddc0ee4b07d03776ac89cbb0e40cd8f17515e96dec7726c
MD5 e1d0cab30ee91e55ec3fb10ad79dc0ff
BLAKE2b-256 332822359836655d075e5ed22eb71c0f1d735cf63a1fc1455dc85a6cb341bad6

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for natsort-3.5.3-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 eea09a230a5b70c44b5ced28ec79ee80389567de7c4ffd25d493a524b53c37a0
MD5 ef5244fccfe6d57ee48ea163b5815c5f
BLAKE2b-256 a93f1b23476f0cc9c303e644c4bcbddec9ccc8c8652f151e29fcad5c5fe4bc71

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