1、首先获取一下pythonwhile循环运行的时间。
2、然后设定一个时间长度,设定调整当时时间如大于这个时间。3、最后会自动退出pythonwhile循环,退出后查看调整完的间隔时间即可。
for 变量 in range(次数):<被执行的语句> 变量:表示每次循环的次数,0-1之间
range(n)n表示产生0到n-1的整数序列共N个 range(m,n) 产生m到n-1的整数序列,共n-m个
循环for语句 :for 循环变量 in遍历结构:<语句体1> else:<语句体2>
无限循环: while条件: 语句块
while 条件:语句体1 else: 语句体2
循环保留字:break continue
方法1:from random import random
from time import perf_counter
DARTS=1000
hits=0.0
start =perf_counter()
for i in range(1,DARTS+1):
x,y=random(),random()
dist=pow(x**2+y**2,0.5)
if dist<=1.0:
hits =hits+1
pi=4*(hits/DARTS)
print("圆周率是:{}".format(pi))
print("运行时间是{:.5f}s".format(perf_counter()-start))
方法2:
pi=0
n=100
for k in range(n):
pi += 1/pow(16,k)*(\
4/(8*k+1)-2/(8*k+4) - \
1/(8*k+5) - 1/(8*k+6))
print("圆周率值是:{}".format(pi))
def 函数名 (0个或者多个):函数体 renturn 返回值
def 函数名 (非可选参数,可选参数):函数体 renturn 返回值
参数传递的两种方式:位置传递,名称传递
科赫雪花:
import turtle
def koch(size,n):
if n==0:
turtle.fd(size)
else:
for angle in [0,60,-120,60]:
turtle.left(angle)
koch(size/3,n-1)
def main():
turtle.setup(400,200)
turtle.penup()
turtle.pendown()
turtle.pensize(2)
l=3
koch(600,l)
turtle.right(120)
turtle.pencolor('blue')
koch(600,l)
turtle.right(120)
turtle.pencolor('red')
koch(600,l)
turtle.speed(3000)
turtle.hideturtle()
main()
阶乘:
def fact(n):
s=1
for i in range(1,n+1):
s*=i
return s
c=eval(input("从键盘输入一个数字"))
print("阶乘结果",fact(c))
楼主说的需要一秒处理一个数据情况需要多线程Threading模块来实现,下面这个程序是我写的一个多线程的例子,希望能帮到楼主=============thread.py===================
#coding:utf8
import time
import random
import datetime
import threading
'''
多线程测试文件
'''
#假定这个方法是楼主所说的处理方法,它需要花费一段时间
def process():
time.sleep(random.random())
print "PROCESS OK!"
#主函数
for x in range(100):
print ">The time is %s." % (datetime.datetime.today().strftime("%H:%M:%S"))
#此处创建一个线程对象
t = threading.Thread(target = process)
t.start()
#一秒处理一个数据
time.sleep(1)
===================
看不懂楼主的意思,楼主有运行过我给你的代码吗?不是多线程可以解决的问题?