背景:
有时候想下载个软件,看到列表里有一大堆的版本,一眼想识别哪个版本是最新的还真有些难度,例如:
1.11.2 和1.4.2 这种,乍一看好像后者的版本更新一点的样子,实际上要按.分割后每个部分各自比较,实在太麻烦了
看看用代码实现起来会不会容易一点
思路:
1、先将不同长度的版本号通过补0变成相同的长度,方便比较(否则无法区别3.9.1和3.9)
2、对每个.分割的部分转为整数进行比较大小,任意部分有大小区别则不再比较
3、如果比较到最后一部分都相等,那说明是同个版本,如(3.9和3.9.0)
4、为了返回版本原值,所以另外加了个变量保存补0后的版本
# coding:utf-8
def compare(a: str, b: str):
'''比较两个版本的大小,需要按.分割后比较各个部分的大小'''
lena = len(a.split('.')) # 获取版本字符串的组成部分
lenb = len(b.split('.'))
a2 = a + '.0' * (lenb-lena) # b比a长的时候补全a
b2 = b + '.0' * (lena-lenb)
print(a2, b2)
for i in range(max(lena, lenb)): # 对每个部分进行比较,需要转化为整数进行比较
if int(a2.split('.')[i]) > int(b2.split('.')[i]):
return a
elif int(a2.split('.')[i]) < int(b2.split('.')[i]):
return b
else: # 比较到最后都相等,则返回第一个版本
if i == max(lena, lenb)-1:
return a
versions = ['1.01', '2.3', '2.12', '2.1.0', '0.0.01.3', '2.154']
last = '0.0' # 给个初始值进行比较
for version in versions:
last = compare(last, version) # 每次将较大的版本取出,留给下次比较
print(last)
PS:lenb < lena时, ‘.0’乘以负数,结果是空字符串