ฉันต้องการที่จะเขียนcmp
ฟังก์ชั่นเหมือนที่เปรียบเทียบตัวเลขสองรุ่นและผลตอบแทน-1
, 0
หรือ1
ขึ้นอยู่กับ valuses เทียบของพวกเขา
- กลับมา
-1
หากเวอร์ชัน A เก่ากว่าเวอร์ชัน B - กลับมา
0
ถ้าเวอร์ชัน A และ B เทียบเท่ากัน - กลับมา
1
หากเวอร์ชัน A ใหม่กว่าเวอร์ชัน B
แต่ละส่วนย่อยควรตีความเป็นตัวเลขดังนั้น 1.10> 1.1
เอาต์พุตฟังก์ชันที่ต้องการคือ
mycmp('1.0', '1') == 0
mycmp('1.0.0', '1') == 0
mycmp('1', '1.0.0.1') == -1
mycmp('12.10', '11.0.0.0.0') == 1
...
และนี่คือการนำไปใช้งานของฉันเปิดให้ปรับปรุง:
def mycmp(version1, version2):
parts1 = [int(x) for x in version1.split('.')]
parts2 = [int(x) for x in version2.split('.')]
# fill up the shorter version with zeros ...
lendiff = len(parts1) - len(parts2)
if lendiff > 0:
parts2.extend([0] * lendiff)
elif lendiff < 0:
parts1.extend([0] * (-lendiff))
for i, p in enumerate(parts1):
ret = cmp(p, parts2[i])
if ret: return ret
return 0
ฉันใช้ Python 2.4.5 btw (ติดตั้งที่ที่ทำงานของฉัน ... )
นี่คือ 'ชุดทดสอบ' ขนาดเล็กที่คุณสามารถใช้ได้
assert mycmp('1', '2') == -1
assert mycmp('2', '1') == 1
assert mycmp('1', '1') == 0
assert mycmp('1.0', '1') == 0
assert mycmp('1', '1.000') == 0
assert mycmp('12.01', '12.1') == 0
assert mycmp('13.0.1', '13.00.02') == -1
assert mycmp('1.1.1.1', '1.1.1.1') == 0
assert mycmp('1.1.1.2', '1.1.1.1') == 1
assert mycmp('1.1.3', '1.1.3.000') == 0
assert mycmp('3.1.1.0', '3.1.2.10') == -1
assert mycmp('1.1', '1.10') == -1