python 模擬貸款卡號(hào)生成規(guī)則過程解析
前言
筆者在測(cè)試某web系統(tǒng)的過程中,需要用到“貸款卡號(hào)”,且此貸款卡號(hào)僅能使用一次,保存過后下一次無(wú)法再次使用相同的卡號(hào)。
遂決定依據(jù)它的生成規(guī)則,自己寫一段代碼來(lái)實(shí)現(xiàn)。
同時(shí)為了方便起見,貸款卡的前三位默認(rèn)用數(shù)字來(lái)實(shí)現(xiàn)。
1. 生成規(guī)則如下:
貸款卡編碼一共有16位,最后兩位是校驗(yàn)位
整個(gè)貸款卡編碼的規(guī)則如下:
前三位:分別為數(shù)字或者大寫英文字母
第四位到第十四位:分別為數(shù)字
后兩位的校驗(yàn)碼為
前十四位乘以權(quán)重相加后除以97后的余數(shù)再加1后得到的數(shù)字,
如果此數(shù)字為個(gè)位數(shù),前面還需要補(bǔ)一個(gè)零
前十四位編碼對(duì)應(yīng)的權(quán)重為1,3,5,7,11,2,13,1,1,17,19,97,23,29
如果某一位為字母,則需要將此字母轉(zhuǎn)換為數(shù)字,A轉(zhuǎn)為為10,B轉(zhuǎn)為為11,以此類推。
2. python代碼如下:
import random power = [1,3,5,7,11,2,13,1,1,17,19,97,23,29] #權(quán)重 arr = [] sum = 0 #隨機(jī)生成前14位并保存在列表arr中 for i in range(14): value = random.randint(0,9) arr.append(value) #前十四位乘以權(quán)重相加 for j in range(14): value = arr[j] * power[j] sum = sum + value #除以97后的余數(shù)再加1 last_two = sum % 97 + 1 #如果此數(shù)字為個(gè)位數(shù),前面還需要補(bǔ)一個(gè)零 if last_two>10: shiwei = last_two // 10 gewei = last_two % 10 arr.append(shiwei) arr.append(gewei) else: shiwei = 0 gewei = last_two arr.append(shiwei) arr.append(gewei) #輸出貸款卡號(hào) print("loanCardNo: ",end="") for i in range(0,16): print(arr[i],end="")
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
關(guān)于tf.TFRecordReader()函數(shù)的用法解析
今天小編就為大家分享一篇關(guān)于tf.TFRecordReader()函數(shù)的用法解析,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來(lái)看看吧2020-02-02關(guān)于Python OS模塊常用文件/目錄函數(shù)詳解
os模塊是操作系統(tǒng)接口模塊,提供了一些方便使用操作系統(tǒng)相關(guān)功能函數(shù),這里介紹下os模塊中對(duì)于文件/目錄常用函數(shù)和使用方法。感興趣的朋友跟隨小編一起看看吧2021-06-06Python隨機(jī)讀取文件實(shí)現(xiàn)實(shí)例
這篇文章主要介紹了Python隨機(jī)讀取文件的相關(guān)資料,需要的朋友可以參考下2017-05-05python實(shí)現(xiàn)圖片處理和特征提取詳解
這篇文章主要介紹了python實(shí)現(xiàn)圖片處理和特征提取詳解,文中向大家分享了Python導(dǎo)入圖片,將圖像轉(zhuǎn)化為二維矩陣,模糊化圖片等Python對(duì)圖像的操作,具有一定參考價(jià)值,需要的朋友可以了解下。2017-11-11用Python實(shí)現(xiàn)校園通知更新提醒功能
今天小編就為大家分享一篇用Python實(shí)現(xiàn)校園通知更新提醒功能,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來(lái)看看吧2019-11-113個(gè)Python?SQLAlchemy數(shù)據(jù)庫(kù)操作功能詳解
Python?SQLAlchemy?是一個(gè)強(qiáng)大且多功能的?Python?SQL?工具包和對(duì)象關(guān)系映射?(ORM)?系統(tǒng),提供了一整套眾所周知的企業(yè)級(jí)持久性模式,本文為大家整理了它必須了解的3個(gè)數(shù)據(jù)庫(kù)操作功能,希望對(duì)大家有所幫助2023-09-09Python multiprocess pool模塊報(bào)錯(cuò)pickling error問題解決方法分析
這篇文章主要介紹了Python multiprocess pool模塊報(bào)錯(cuò)pickling error問題解決方法,結(jié)合實(shí)例形式分析了multiprocess pool模塊報(bào)錯(cuò)pickling error的原因與解決方法,需要的朋友可以參考下2019-03-03