经常在Linux下操作文件,要对一组文件名保存起来使用的时候,需要排序,但是文件名是字符串,自然排序结果会出现这种问题:
源数据:
5.rb 2.rb 201.rb 51.rb 7.rb 4.rb
系统提供的排序方法结果是这样的:
2.rb 201.rb 4.rb 5.rb 51.rb 7.rb
这明显是不对的,201当然应该排在最后,只是当成字符串来处理,就会有这样的问题,所以用Python写个小程序再处理一遍:
l = ['5.rb', '2.rb', '201.rb', '51.rb', '7.rb', '4.rb']
print 'Before:'
print l
for i in range(len(l)):
l[i] = l[i].split('.')
l[i][0] = int(l[i][0])
print 'After:'
print l
l.sort()
print 'Sorted:'
print l
for i in range(len(l)):
l[i][0] = str(l[i][0])
l[i] = l[i][0] + '.' + l[i][1]
print 'Recover:'
print l
思路很简单,把文件名拆分之后转成整数,再排序,然后再转回来即可。
运行结果: