SN生成流水号并且打乱

目前公司的产品会通过sn绑定账号,但是会出现一个问题,流水号会容易被人猜出来导致被他人在未授权的情况下使用,所以开发了一个生成流水号后打乱的python程序,比如输入sn的前11位后,后面的字符所有的排列组合有26^4方种,然后随机打乱后,取这次生产要用的前10000个,这样可以降低被猜中的概率,以下是实现的代码,至于说如何保证不同批次的sn不重复,只要保证前11位不重复即可

使用方式如下,先按要求输入前11位,然后输入你的字符集,比如 a,b,c,d,e 这样就会穷尽这几个的排列组合后打乱 当然可以是任意字符 比如特殊字符@#$这种 或者你可以26个字母里面排除某些字母作为后面4位字符排列组合时选取的字符集,最后会生成csv格式的文件,方便给工厂的生成流程使用

python 复制代码
import random
import csv
from itertools import product

def generate_custom_sn_csv():
    # 输入前11位SN(自动验证长度)
    prefix = input("请输入前11位SN:").strip()
    while len(prefix) != 11:
        print("错误:必须输入恰好11个字符!")
        prefix = input("请重新输入前11位SN:").strip()

    # 输入自定义字符集合
    chars = input("请输入后4位字符集合(例如:a,b,c,d,e,f):").strip()
    char_set = [c.strip() for c in chars.split(',')] if chars else []
    
    while not char_set or len(char_set) < 2:
        print("错误:至少需要2个不同字符!")
        chars = input("请重新输入后4位字符集合(例如:a,b,c,d,e,f):").strip()
        char_set = [c.strip() for c in chars.split(',')]

    # 生成所有4位排列组合
    all_combinations = [''.join(p) for p in product(char_set, repeat=4)]
    
    # 随机打乱顺序
    random.shuffle(all_combinations)

    # 生成完整SN列表
    sn_list = [f"{prefix}{suffix}" for suffix in all_combinations]

    # 写入CSV文件
    filename = f"custom_sns_{len(char_set)}chars.csv"
    with open(filename, 'w', newline='', encoding='utf-8') as csvfile:
        writer = csv.writer(csvfile)
        writer.writerow(['Serial_Number'])  # 写入标题行
        writer.writerows([[sn] for sn in sn_list])  # 逐行写入SN

    print(f"成功生成包含{len(sn_list)}个SN的CSV文件:{filename}")
    print(f"字符集合:{char_set},排列组合总数:{len(char_set)**4}")
    print("示例数据预览:")
    print(sn_list[:10])  # 打印前10个结果预览

if __name__ == "__main__":
    generate_custom_sn_csv()

生成如下

相关推荐
掘金安东尼5 小时前
纯 CSS 实现弹性文字效果
前端·css
牛奶6 小时前
Vue 基础理论 & API 使用
前端·vue.js·面试
牛奶6 小时前
Vue 底层原理 & 新特性
前端·vue.js·面试
anOnion6 小时前
构建无障碍组件之Radio group pattern
前端·html·交互设计
pe7er6 小时前
状态提升:前端开发中的状态管理的设计思想
前端·vue.js·react.js
SoaringHeart7 小时前
Flutter调试组件:打印任意组件尺寸位置信息 NRenderBox
前端·flutter
晚风予星8 小时前
Ant Design Token Lens 迎来了全面升级!支持在 .tsx 或 .ts 文件中直接使用 Design Token
前端·react.js·visual studio code
sunny_8 小时前
⚡️ vite-plugin-oxc:从 Babel 到 Oxc,我为 Vite 写了一个高性能编译插件
前端·webpack·架构
GIS之路8 小时前
ArcPy 开发环境搭建
前端
林小帅10 小时前
【笔记】OpenClaw 架构浅析
前端·agent