random函数汇总

random函数汇总1 random randomrandom random 用于生成一个 0 到 1 之间的随机浮点数 0 lt n lt 1 gt gt gt random random 0 random uniformrando uniform a b 用于生成一个指定范围内的随机浮点数 若 a lt b 则 a lt n lt b 若 a gt

1. random.random

random.random()用于生成一个0到1之间的随机浮点数:0<=n<1

>>> random.random() 0.96296

2. random.uniform

random.uniform(a,b)用于生成一个指定范围内的随机浮点数若a<b,则a<=n<=b;若a>b,则b<=n<=a.

>>> random.uniform(12,5) 6.2529 >>> random.uniform(5,12) 5.9382 >>> random.uniform(5,5) 5.0

3. random.randint

random.randint(a,b)用于生成一个指定范围内的整数:a<=n<=b;下限必须小于等于上限值,random.randint(20,10)是错误的

>>> random.randint(10,10) 10 >>> random.randint(10,21) 15 >>> random.randint(100,100) 100

4. random.randrange

random.randrange([start],[stop],[step])从指定范围内,按指定基数递增的集合中获取一个随机数。等于random.choice(range([start],[stop],[step]))

>>> random.randrange(1,100,10) 61 >>> random.randrange(1,100,10) 21 >>> random.choice(range(1,100,10)) 71 >>> random.choice(range(1,100,10)) 41 >>> random.randrange(100,100) Traceback (most recent call last):   File "<stdin>", line 1, in <module>   File "/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/random.py", line 199, in randrange     raise ValueError("empty range for randrange() (%d,%d, %d)" % (istart, istop, width)) ValueError: empty range for randrange() (100,100, 0)

5. random.choice

random.choice(seq)从序列中获取随机一个元素

choices(population, weights=None, *, cum_weights=None, k=1)这个方法平时比较少用,population是一个可迭代对象,weights是相对权重,cum_weights是累积权重,k表示随机获取的个数。

例如,相对权重“[10, 5, 30, 5]“相当于累积权重“[10, 15, 45, 50]“。 在内部,相对权重在进行选择之前会转换为累积权重,因此提供累积权重可以节省工作量。random官方文档

需要注意2点:

1. weights和cum_weights不能同时使用。

2.population与weights,population与cum_weights需一一对应

>>> random.choice("abcde") 'd' >>> random.choice([1,2,3,4]) 2 >>> random.choice((1.1,2.2,3.3,4.4)) 3.3 >>> for i in range(10): ... print(random.choices("abcd",weights=[1,1,7,1],cum_weights=[70,10,5,15],k=1)) ... Traceback (most recent call last): File "<stdin>", line 2, in <module> File "E:\Programs\Python36\lib\random.py", line 356, in choices raise TypeError('Cannot specify both weights and cumulative weights') TypeError: Cannot specify both weights and cumulative weights >>> for i in range(10): ... print(random.choices(['x','y','z'],cum_weights=[70,10,5,15],k=1)) ... Traceback (most recent call last): File "<stdin>", line 2, in <module> File "E:\Programs\Python36\lib\random.py", line 358, in choices raise ValueError('The number of weights does not match the population') ValueError: The number of weights does not match the population >>> for i in range(10): ... print(random.choices(['x','y','z','u'],cum_weights=[70,10,5],k=1)) ... Traceback (most recent call last): File "<stdin>", line 2, in <module> File "E:\Programs\Python36\lib\random.py", line 358, in choices raise ValueError('The number of weights does not match the population') ValueError: The number of weights does not match the population >>> for i in range(10): ... print(random.choices("abcd",weights=[1,1,7,1],k=1)) ... ['b'] ['c'] ['c'] ['c'] ['c'] ['c'] ['a'] ['a'] ['c'] ['c'] 由上可以明显发现,随机获得c的概率更高 >>> for i in range(10): ... print(random.choices(['x','y','z','w'],cum_weights=[70,10,5,15],k=1)) ... ['w'] ['w'] ['w'] ['w'] ['x'] ['x'] ['w'] ['x'] ['x'] ['x']

6. random.shuffle

random.shuffle(x[, random])用于将一个列表中的元素打乱

>>> l=['a','b','c','d','e'] >>> random.shuffle(l) >>> l ['d', 'b', 'e', 'c', 'a']

7. random.sample

random.sample(seq,k)从指定序列中随机获取指定长度的,且不重复出现的片段

>>> l=['a','b','c','d','e'] >>> s=random.sample(l,2) >>> s ['c', 'a'] >>> l ['a', 'b', 'c', 'd', 'e']

8. random.seed

random.seed(n)用于改变随机数生成器的种子,指定随机数生成时所用的算法

>>> random.seed(2) >>> random.random() 0.92494 >>> random.random() 0.93494 

9. 实践

写一个函数:随机生成n个整数,n个整数的和等于m

import random def random_num(n, m): # 随机生成n个数字 numbers = [random.random() for _ in range(n)] # 计算出 m 与 n个随机数的商 k = m / sum(numbers) # n个随机数分别乘以k,n个数的和接近于m result = [int(i * k) for i in numbers] # 从result中随机选择一个数,加上m与sum(result)的差数,从而实现sum(result) = m result[random.randint(0,n-1)] += m - sum(result) print("sum(result)=", sum(result)) print("result=", result) >>> random_num(5, 100) sum(result)= 100 result= [5, 21, 15, 33, 26] >>> random_num(2, 15) sum(result)= 15 result= [2, 13] >>>

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/232717.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • JVM性能调优监控工具jps、jstack、jmap、jhat、jstat、hprof使用详解

    JVM性能调优监控工具jps、jstack、jmap、jhat、jstat、hprof使用详解摘要:JDK本身提供了很多方便的JVM性能调优监控工具,除了集成式的VisualVM和jConsole外,还有jps、jstack、jmap、jhat、jstat、hprof等小巧的工具,本博客希望能起抛砖引玉之用,让大家能开始对JVM性能调优的常用工具有所了解。现实企业级Java开发中,有时候我们会碰到下面这些问题: OutOfMemoryError,内存不足 内存…

    2022年5月2日
    42
  • Spring Cloud Greenwich.RELEASE 正式发布!一个非常有看头的版本!

    Spring Cloud Greenwich.RELEASE 正式发布!一个非常有看头的版本!译文来源 Spring 技术社区 SpringCloudG RELEASE 现已正式发布 可以在 SpringMilest 和 MavenCentral 库获取到 也可以查看 Greenwich 发布说明了解更多信息 寿命终止 EOL 提醒 Edgware 版本将于 2019 年 8 月 1 日进入 EOL 状态 详细说明参见 Spring

    2025年7月23日
    4
  • SQL datetime和smalldatetime区别

    SQL datetime和smalldatetime区别datetime存储大小8个字节,精确到分后的3为小数,日期范围从1753年1月1日到9999年12月31日;而smalldatetime存储大小为4个字节,精确到分,日期范围从1900年1月1日到2079年6月6日。参考http://msdn.microsoft.com/zh-cn/library/ms187819%28v=…

    2022年7月27日
    5
  • 敏感文件/目录扫描工具 dirsearch「建议收藏」

    敏感文件/目录扫描工具 dirsearch「建议收藏」目录1、dirsearch是什么?2、dirsearch的下载和安装3、在dirsearch.py所在目录,输入cmd,进入命令行4、dirsearch的参数5、实战6、查看响应码为200的目录1、dirsearch是什么?dirsearch是一个python开发的目录扫描工具。和我们平时使用的御剑之类的工具一样,就是为了扫描网站的敏感文件和目录从而找到突破口。2、dirsearch的下载和安装下载地址:http://链接:https:…

    2022年10月5日
    2
  • SpringCloud和dubbo的区别[通俗易懂]

    SpringCloud和dubbo的区别[通俗易懂]SpringCloud跟dubbo的区别从架构层面上来说SpringCloud跟dubbo都是微服务架构在公司开发技术选型中:SpringCloud的维护成本比较高,但是SpringCloud中提供了很多框架、整合了5大组件(全家桶:Ribbon负载均衡、eureka注册中心、Hystrix熔断器、gateway网关、feign服务调用)使用都非常方便,后期便于维护,分布式单一互不影响原则…

    2022年4月30日
    70
  • mysql 锁表详解

    mysql 锁表详解为了给高并发情况下的MySQL进行更好的优化,有必要了解一下mysql查询更新时的锁表机制。一、概述MySQL有三种锁的级别:页级、表级、行级。MyISAM和MEMORY存储引擎采用的是表级锁(table-levellocking);BDB存储引擎采用的是页面锁(page-levellocking),但也支持表级锁;InnoDB存储引擎既支持行级锁(row-levellocki

    2022年6月3日
    103

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号