python - 求字符串版本号比较算法!
迷茫
迷茫 2017-04-17 11:56:25
[Python讨论组]
远程版本号: "1.1.1"
本地版本号: "2.0"

字符串保存,大家是怎么比较的呢?

迷茫
迷茫

业精于勤,荒于嬉;行成于思,毁于随。

全部回复(7)
高洛峰

SemVer for Objective-C
https://github.com/thisandagain/semver

PHPz
  1. 利用自然排序算法,对版本号进行升序排序,后面的版本号自然比前面的版本号大
  2. 利用正则表达式匹配出 majorversion,minorversion,revision_nubmer,然后分别比较
  3. 将字符串用“.”分割后转化为大小为3的数组,不够的添加0,然后对数组进行比较
ringa_lee

首先你自己要有一个比较标准,比如数字升高版本号也偏大的话直接比较字符就好,用

String s1 = "2.2.1";
String s2 = "1.2";
String[] tmp1 = s1.split("\\.");
String[] tmp2 = s2.split("\\.");

然后逐项比较应该也可以吧?不过要注意长度不同类似于2.2和2.2.1的这种比较应该就可以了。

ringa_lee

也来贴一个Objective-C的:

@implementation NSString(Version)

-(BOOL) isOlderVersionThan:(NSString*)otherVersion
{
return ([self compare:otherVersion options:NSNumericSearch] == NSOrderedAscending);
}

-(BOOL) isNewerVersionThan:(NSString*)otherVersion
{
return ([self compare:otherVersion options:NSNumericSearch] == NSOrderedDescending);
}

@end

这看来是OC最简单的方法了,用NSString的compare方法,不知道有人这样用过没?

大家讲道理

我大Python怎么会没有库

In [1]: from distutils.version import LooseVersion                                                                                                                                                                                                                                                                                                                                                
In [2]: LooseVersion('1.0.0')                                                                                                                                                                                  
Out[2]: LooseVersion ('1.0.0')                                                                                                                                                                                  
In [3]: LooseVersion('2.0')                                                                                                                                                                                
Out[3]: LooseVersion ('2.0')                                                                                                                                                                                    
In [4]: cmp(_2,_3)                                                                                                                                                     
Out[4]: -1
In [5]: LooseVersion('1.0b')                                                                                                                                                                       
Out[5]: LooseVersion ('1.0b')
In [7]: cmp(_2,_5)                                                                                                                                                                                  
Out[7]: -1
伊谢尔伦

JavaScript 实现. 原理就是按 . 分开, 然后按位比较呗.

/*
  字符串比较
  返回值:
    0: 相等
    1: 大于
   -1: 小于
*/
function versionCompare( stra, strb ) {
  var straArr = stra.split('.');
  var strbArr = strb.split('.');
  var maxLen = Math.max( straArr.length, strbArr.length );
  var result, sa, sb;
  for ( var i = 0; i  sb){
      result = 1;
    }
    else if(sa 
阿神
>>> num = '@"1.1.1"'
>>> num1 = '@"1.1.1"'
>>> def run(s):
    return s.strip('@"').split('.')
>>> run(num1)
['1', '1', '1']
>>> run(num2)
['2', '0']
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号