列表的sort(方法)除了给数字排序。对字符串有什么作用?
p=["一","二","三","四","五","六","七","八","九","十"]p.sort()
print(p)
结果是
['一', '七', '三', '九', '二', '五', '八', '六', '十', '四']
想知道为什么
希望各位解答
sort()方法对字符串列表的作用是按照字母顺序进行排序。在你给出的例子中,列表p包含了汉字表示的数字。在汉字字符集中,每个汉字都有一个对应的Unicode码点,而sort()方法默认按照Unicode码点的顺序对字符串进行排序。
根据Unicode码点的顺序,一些汉字的排序可能与我们习惯的数字顺序不同。例如,在你的例子中,"一"的码点是19968,"七"的码点是19971,因此"七"排在"一"的后面。类似地,其他汉字也根据其码点的顺序进行排序。
如果你希望按照汉字表示的数字的顺序进行排序,你可以使用自定义的排序方法,例如利用key参数传递一个函数来指定排序规则。以下是一个示例代码:
p = ["一", "二", "三", "四", "五", "六", "七", "八", "九", "十"]
p.sort(key=lambda x: ['一', '二', '三', '四', '五', '六', '七', '八', '九', '十'].index(x))
print(p)
这段代码会按照汉字表示的数字的顺序对列表进行排序,并输出结果:['一', '二', '三', '四', '五', '六', '七', '八', '九', '十']。
希望能解答你的疑问!如果还有其他问题,请随时提问。
如果问题已经解决,请设置最佳答案 对字符串排序是根据unicode码值的,可以用 ord 函数获取字符的 unicode 码值
页:
[1]