作者oaz (台湾独立建国不必钱吗?)
看板Python
标题Re: [教学] 排序问题
时间Tue Nov 17 00:17:36 2009
※ 引述《g9678007 (HKE)》之铭言:
: 抱歉,刚刚有点太慌乱。
: 小弟是要排序 例如 GG=['NM_M_3.3','NM_M_3.13','NM_M_3.11']
: 我想要照数字大小排序
: 但是如果利用GG.sort() 会变
: ['NM_M_3.11', 'NM_M_3.13', 'NM_M_3.3']
: 他变成只排序小数点後面1然後由小到大
: 我想要的是
: [ 'NM_M_3.3','NM_M_3.11', 'NM_M_3.13']
: 问题是卡在字串里面前後都夹很多字串,我有想过直接把字理的
: 3.3 3.11 3.13 取出来在转float比大小就不会有这问题,但是每次的档名
: 都不是很规则不能单纯任位子
: 我在举个例像
: GG=['NM_M_3.3','NM_M_3.13','NM_M_3.11','NM_M_3.9','NM_M_3.1']
: GG.sort()
: ['NM_M_3.1', 'NM_M_3.11', 'NM_M_3.13', 'NM_M_3.3', 'NM_M_3.9']
: 问题是我想要的是
: ['NM_M_3.1', 'NM_M_3.3', 'NM_M_3.9', 'NM_M_3.11', 'NM_M_3.13']
: 单纯用python语法可以做到嘛?
我在想,你的排序规则会不会是:
先照小数点後的位数法,由少到多
而位数若一样,则由小到大
def your_cmp(x, y):
if len(x)==len(y):
return cmp(x, y)
else:
return len(x)-len(y)
GG.sort(cmp=your_cmp)
: ※ 引述《sbrhsieh (偶尔想摆烂一下)》之铭言:
: : 说真的,看不懂你的推文是什麽意思?
: : 如果文章内容有打错,不能花点时间修改一下你的文章内容吗?
: : 别人问你 [ 'NM_M_3.3','NM_M_3.11', 'NM_M_3.13'] 是依什麽顺序,你回答说依照
: : 数字大小排序,问题是这到底是什麽样的大小的顺序?
: : 我猜你要的是降幂:'NM_M_3.3','NM_M_3.13', 'NM_M_3.11'。
: : 可以在 sort 操作指定反序(for Python 2.4+):
: : GG.sort(reverse=True)
--
※ 发信站: 批踢踢实业坊(ptt.cc)
◆ From: 140.112.30.32