Clarify SortingHOWTO regarding locale aware string sorting · Issue #91415 · python/cpython (original) (raw)

New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service andprivacy statement. We’ll occasionally send you account related emails.

Already on GitHub?Sign in to your account

Closed

CendioOssman mannequin opened this issue

Apr 8, 2022

· 3 comments

Assignees

@rhettinger

Labels

3.10

only security fixes

3.11

only security fixes

docs

Documentation in the Doc dir

Comments

@CendioOssman

BPO 47259
Nosy @rhettinger, @stevendaprano, @CendioOssman

Note: these values reflect the state of the issue at the time it was migrated and might not reflect the current state.

Show more details

GitHub fields:

assignee = 'https://github.com/rhettinger' closed_at = None created_at = <Date 2022-04-08.10:31:59.766> labels = ['3.11', '3.10', 'docs'] title = 'Clarify SortingHOWTO regarding locale aware string sorting' updated_at = <Date 2022-04-08.17:49:04.631> user = 'https://github.com/CendioOssman'

bugs.python.org fields:

activity = <Date 2022-04-08.17:49:04.631> actor = 'rhettinger' assignee = 'rhettinger' closed = False closed_date = None closer = None components = ['Documentation'] creation = <Date 2022-04-08.10:31:59.766> creator = 'CendioOssman' dependencies = [] files = [] hgrepos = [] issue_num = 47259 keywords = [] message_count = 2.0 messages = ['416972', '416997'] nosy_count = 3.0 nosy_names = ['rhettinger', 'steven.daprano', 'CendioOssman'] pr_nums = [] priority = 'normal' resolution = None stage = None status = 'open' superseder = None type = None url = 'https://bugs.python.org/issue47259' versions = ['Python 3.10', 'Python 3.11']

@CendioOssman

There is a big gotcha in Python that is easily overlooked and should at the very least be more prominently pointed out in the documentation.

Sorting strings will produce results that is very confusing for humans.

I happens to work for ASCII, but will generally produce bad results for other things as code points do not always follow the alphabetical order.

The expressions chapter¹ mentions this fact, but you have to dig quite a bit to reach that. It also mentions that normalization is an issue, but it never mentions the issue about code point order versus alphabetical order.

The sorting tutorial mentions under "Odds and ends"² that you need to use a special key or comparison function to get locale aware sorting. It doesn't mention that this also includes respecting alphabetical order, which might be overlooked unless you are very familiar with how the sorting works. The tutorial is also something you have to dig a bit to reach.

Ideally string comparison would always be locale aware in a high level language such as Python. However, a smaller step would be a note on sorted()³ that extra care needs to be taken for strings as the default behaviour will produce unexpected results once your strings include anything outside the English alphabet.

¹ https://docs.python.org/3/reference/expressions.html
² https://docs.python.org/3/howto/sorting.html#odd-and-ends
³ https://docs.python.org/3/library/functions.html#sorted

@rhettinger

I don't think splashing this everywhere else in the docs would be helpful. Tools like list.sort, sorted, min, max, nlargest, nsmallest use whatever sort order is provided by the underlying object whether it be a string, tuple, float, or int.

The section on expressions is the intended place to cover how comparison are defined for core objects: https://docs.python.org/3/reference/expressions.html#value-comparisons

As suggested, I will edit the sorting howto to be cleared that locale aware sort ordering refers to alphabetical orderings which can vary (for example, the Spanish ll sorts differently in different locales).

@rhettinger rhettinger changed the titlestring sorting often incorrect Clarify SortingHOWTO regarding locale aware string sorting

Apr 8, 2022

@rhettinger rhettinger changed the titlestring sorting often incorrect Clarify SortingHOWTO regarding locale aware string sorting

Apr 8, 2022

@andjc

Actually sorting, and collation in general, can be quite a complex topic, I am slowly working through writing my own notes on it, and it can bend the mind at times.

You have various approaches to sorting, including:

You could probably write a whole book just to properly address available customisations to CLDR collations.

Added to that, you have the differences in locales between GNU/Linux, BSD/macOS, and Windows, and the fact that many locale collation tables on BSD and macOS are symlinked to one specific collation table (which negates the ability for language tailored collation).

Then you have emoji collation sequences and the possibility of building custom collation rules, combining language tailored collation with emoji collation.

rhettinger added a commit to rhettinger/cpython that referenced this issue

Oct 16, 2022

@rhettinger

miss-islington pushed a commit to miss-islington/cpython that referenced this issue

Oct 16, 2022

@rhettinger @miss-islington

…TO (pythonGH-98336)

(cherry picked from commit ae19217)

Co-authored-by: Raymond Hettinger rhettinger@users.noreply.github.com

miss-islington added a commit that referenced this issue

Oct 16, 2022

@miss-islington @rhettinger

…-98336)

(cherry picked from commit ae19217)

Co-authored-by: Raymond Hettinger rhettinger@users.noreply.github.com

carljm added a commit to carljm/cpython that referenced this issue

Oct 17, 2022

@carljm

pablogsal pushed a commit that referenced this issue

Oct 22, 2022

…-98336)

(cherry picked from commit ae19217)

Co-authored-by: Raymond Hettinger rhettinger@users.noreply.github.com

Labels

3.10

only security fixes

3.11

only security fixes

docs

Documentation in the Doc dir

2 participants

@andjc @rhettinger