这可能对您有帮助。编辑正则表达式以匹配您感兴趣的数字模式。Mine将把包含的所有数字字段都
.视为浮点数。用于
swapcase()颠倒您的情况,以便排
'A'在后面
'a'。
更新 :改进:
import redef _human_key(key): parts = re.split('(d*.d+|d+)', key) return tuple((e.swapcase() if i % 2 == 0 else float(e)) for i, e in enumerate(parts))nums = ['9', 'aB', '1a2', '11', 'ab', '10', '2', '100ab', 'AB', '10a', '1', '1a', '100', '9.9', '3']nums.sort(key=_human_key)print 'n'.join(nums)
输出:
11a1a22399.91010a11100100ababaBAB
更新
:(响应评论)如果您有一个类
Foo并且想要
__lt__使用
_human_key排序方案来实现,则只需返回
_human_key(k1) <_human_key(k2);的结果即可。
class Foo(object): def __init__(self, key): self.key = key def __lt__(self, obj): return _human_key(self.key) < _human_key(obj.key)>>> Foo('ab') < Foo('AB')True>>> Foo('AB') < Foo('AB')False
因此,对于您的情况,您将执行以下 *** 作:
def __lt__(self, other): column = self.treeWidget().sortColumn() k1 = self.text(column) k2 = other.text(column) return _human_key(k1) < _human_key(k2)
其他比较运算符(
__eq__,
__gt__等)将以相同的方式实现。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)