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()

生成如下

相关推荐
IT_陈寒几秒前
Vite性能优化实战:5个被低估的配置让你的开发效率提升50%
前端·人工智能·后端
IT_陈寒3 分钟前
Java性能调优的7个被低估的技巧:从代码到JVM全链路优化
前端·人工智能·后端
ゞ 正在缓冲99%…4 分钟前
leetcode1770.执行乘法运算的最大分数
java·数据结构·算法·动态规划
渡我白衣9 分钟前
链接的迷雾:odr、弱符号与静态库的三国杀
android·java·开发语言·c++·人工智能·深度学习·神经网络
007php00723 分钟前
大厂深度面试相关文章:深入探讨底层原理与高性能优化
java·开发语言·git·python·面试·职场和发展·性能优化
掘金安东尼28 分钟前
前端周刊第439期(2025年11月3日–11月9日)
前端·javascript·vue.js
qq_3344668636 分钟前
excel VBA应用
java·服务器·excel
码农刚子38 分钟前
ASP.NET Core Blazor进阶1:高级组件开发
前端·前端框架
E_ICEBLUE38 分钟前
快速合并 Excel 工作表和文件:Java 实现
java·microsoft·excel
春风霓裳41 分钟前
ubuntu磁盘管理、磁盘扩容
linux·运维·ubuntu