Измерьте временной интервал между началом выполнения программы python и окончанием ее выполнения - PullRequest
0 голосов
/ 10 января 2020

Я пытался добавить код в свой скрипт pong.py ниже, чтобы измерить время, в течение которого экран остается открытым и закрывается. У меня проблемы с запуском Pygame, поэтому я хотел бы найти способ рассчитать этот интервал времени без использования Pygame. Я рассмотрел несколько проблем здесь в stack.overflow, но ни одна из них не учитывает время, в течение которого моя python экранная программа остается открытой. И некоторые ответы имеют pygame, и я избегаю pygame для получения сообщений об ошибках.

pong.py:

    # Simple Pong in Python 3 for Beginners
# By @TokyoEdTech
# Part 5: Colliding with the paddles

import turtle

wn = turtle.Screen()
wn.title("Pong by @TokyoEdTech")
wn.bgcolor("black")
wn.setup(width=800, height=600)
wn.tracer(0)

# Paddle A
paddle_a = turtle.Turtle()
paddle_a.speed(0)
paddle_a.shape("square")
paddle_a.color("white")
paddle_a.shapesize(stretch_wid=5, stretch_len=1)
paddle_a.penup()
paddle_a.goto(-350, 0)

# Paddle B
paddle_b = turtle.Turtle()
paddle_b.speed(0)
paddle_b.shape("square")
paddle_b.color("white")
paddle_b.shapesize(stretch_wid=5, stretch_len=1)
paddle_b.penup()
paddle_b.goto(350, 0)

# Ball
ball = turtle.Turtle()
ball.speed(0)
ball.shape("square")
ball.color("white")
ball.penup()
ball.goto(0, 0)
ball.dx = 2
ball.dy = -2

# Function
def paddle_a_up():
    y = paddle_a.ycor()
    y += 20
    paddle_a.sety(y)

def paddle_a_down():
    y = paddle_a.ycor()
    y -= 20
    paddle_a.sety(y)

def paddle_b_up():
    y = paddle_b.ycor()
    y += 20
    paddle_b.sety(y)

def paddle_b_down():
    y = paddle_b.ycor()
    y -= 20
    paddle_b.sety(y)

# Keyboard binding
wn.listen()
wn.onkeypress(paddle_a_up, "w")
wn.onkeypress(paddle_a_down, "s")
wn.onkeypress(paddle_b_up, "Up")
wn.onkeypress(paddle_b_down, "Down")

# Main game loop
while True:
    wn.update() 

    # Move the ball
    ball.setx(ball.xcor() + ball.dx)
    ball.sety(ball.ycor() + ball.dy)

    # Border checking
    if ball.ycor() > 290:
        ball.sety(290)
        ball.dy *= -1

    if ball.ycor() < -290:
        ball.sety(-290)
        ball.dy *= -1

    if ball.xcor() > 390:
        ball.goto(0, 0)
        ball.dx *= -1

    if ball.xcor() < -390:
        ball.goto(0, 0)
        ball.dx *= -1

    # Paddle and ball collisions
    if (ball.xcor() > 340 and ball.xcor() < 350) and (ball.ycor() < paddle_b.ycor() + 40 and ball.ycor() > paddle_b.ycor() -40):
        ball.setx(340)
        ball.dx *= -1

    if (ball.xcor() < -340 and ball.xcor() > -350) and (ball.ycor() < paddle_a.ycor() + 40 and ball.ycor() > paddle_a.ycor() -40):
        ball.setx(-340)
        ball.dx *= -1

ОБНОВЛЕНИЕ

SAMPLE

Я имел в виду, когда я был с открытым экраном, например, если это была игра, я должен считать время, пока я держу программу открытой.

Мне бы хотелось, чтобы он работал в скрипте, но мне также интересны командные строки.

Ответы [ 2 ]

1 голос
/ 10 января 2020

Здравствуйте,

Существует множество способов узнать время выполнения программы в Python.

Я упомяну два простых и распространенных способа: -

  • Использовать временную библиотеку

time - это библиотека в python, используемая для манипуляции и воспроизведения со временем.

import time
start = time.time()
...
...
print(time.time() - start)
  • В командной строке

Если вы запускаете программы из командной строки, вы можете попробовать это.

$ time python3 code.py

Эта строка дает основную c информацию о том, сколько времени занимает система для запуска кода.

1 голос
/ 10 января 2020

Вы пробовали этого хорошего сэра?

import turtle 
import time
start_time = time.time()
#Set up the screen 
try:
    wn = turtle.Screen() 
    wn.bgcolor("black") 
    wn.title("Test") 
    wn.bgpic("grid.png")
    print("Execution time :  %s seconds " % (str(time.time() - start_time)))
except Exception as e:
    print("Program exited by error",e)
    print("Execution time : %s seconds " % (str(time.time() - start_time)))

...