有什么好的方法可以生成十万条不重复的13位纯数字字符串
有什么好的方法可以生成十万条不重复的13位纯数字字符串
一个个来。从13个0开始,一次加1。。。
可用时间戳来生成,或者后面再加随机数
<code>package com.xtl.demo; import java.util.HashSet; import java.util.Random; import java.util.Set; /** * 生成20组不重复的13位数随机数 * @author xiatianlong * * @date 2016年10月8日 上午11:44:57 */ public class CreatRandomNumber { public static void main(String[] args) { Set<string> numberSet = new HashSet<string>(); while(true){ // 数量大于20条即结束 if (numberSet.size()>20){ break; } String randomNumber = createRandomNumber(13); numberSet.add(randomNumber); } for (String string : numberSet) { System.out.println(string); } } /** * 生成指定位数的随机数 * @param length * 生成的位数 * @return */ public static String createRandomNumber(int length){ String number =""; for (int i = 0; i<length i int randomnumber="new" random number return></length></string></string></code>
没怎么考虑性能。。。
随便单向加密个字符再加盐,取13位不就行了。
python 里可用 random.sample
:
<code>random.sample(range(10**12, 10**13), 10**5) </code>
python2 用 xrange
,如果要从零开始用 format
。