Chinaunix首页 | 论坛 | 博客
  • 博客访问: 2290105
  • 博文数量: 297
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 2200
  • 用 户 组: 普通用户
  • 注册时间: 2014-03-31 14:30
个人简介

自己慢慢积累。

文章分类

全部博文(297)

分类: Python/Ruby

2020-11-09 15:07:27

基于Python生成短8位唯一id解决方案
转载自:
https://www.cnblogs.com/shouke/p/13423073.html
by:授客 QQ:1033553122

测试环境:
Win10
Python 3.8.3

实现思路
利用62个可打印字符,通过随机生成32位UUID,由于UUID都为十六进制,所以将UUID分成8组,每4个为一组,然后通过模62(字符0-9,a-z,A-Z总数量62个字符)操作,结果作为索引取出字符,这样重复率大大降低,实践测试,运行20000000次,仅出现2个重复id(仅测试过一次)。
当然,这样还达不到唯一id,因为还是有重复的。解决方法呢,可以考虑结合数据库、或者其它存储来实现,以结合数据库为例,我们可以新建一张数据库表,并给表设置一个id字段,并且设置为主键、或者增加唯一约束,每次获取8 id后,往表里插入一条数据,如果可以成功插入,说明不重复,否则说明是重复id,再次尝试获取。


核心代码

  1. #!/usr/bin/env python
  2. # -*- coding:utf-8 -*-
  3.  
  4. '''
  5. @CreateTime: 2020/07/14 11:04
  6. @Author : shouke
  7. '''

  8. import uuid
  9. array = [ "0", "1", "2", "3", "4", "5","6", "7", "8", "9",
  10.           "a", "b", "c", "d", "e", "f","g", "h", "i", "j", "k", "l", "m", "n", "o", "p", "q", "r", "s","t", "u", "v", "w", "x", "y", "z",
  11.           "A", "B", "C", "D", "E", "F", "G", "H", "I","J", "K", "L", "M", "N", "O", "P", "Q", "R", "S", "T", "U", "V","W", "X", "Y", "Z"
  12.           ]
  13.  
  14. def get_short_id():
  15.     id = str(uuid.uuid4()).replace("-", '') # 注意这里需要用uuid4
  16.     buffer = []
  17.     for i in range(0, 8):
  18.         start = i * 4
  19.         end = i * 4 + 4
  20.         val = int(id[start:end], 16)
  21.         buffer.append(array[val % 62])
  22.     return "".join(buffer)
# 测试验证代码

  1. id_set = set() # 用于存放生成的唯一id
  2. count = 0 # 用于统计出现重复的次数
  3. index = [] # 记录第几次调用生成8位id出现重复
  4. for i in range(0, 20000000):
  5.     id = get_short_id()
  6.     if id in id_set:
  7.         count += 1
  8.         index.append(str(i+1))
  9.     else:
  10.         id_set.add(id)
  11.     print('id:%s, 运行第 %s 次, 重复数:%s , 重复率:%s, 出现重复次序 %s' % (id, i+1, count, count/(i+1)*100, ','.join(index)))

我自己测试了3次:
第一次跑了200万次,没有重复
第二次跑到第69万次就出现了一次重复
第三次跑了700万次,没有重复。 
阅读(1594) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~