Save in a variable the number of seconds a process took to run

后端 未结 5 686
走了就别回头了
走了就别回头了 2021-02-04 17:15

I want to run a process in bash and save in an env variable the number of seconds it took to run. How would I do such a thing?

相关标签:
5条回答
  • 2021-02-04 17:43

    Using $SECONDS wasn't working for me in a script run by cron (though it worked when I ran it directly; I used cron for the first time today, so there could be some user error too). @Farzy's answer using TIMEFORMAT worked but I didn't want to redirect the output from the timed command. Here's an alternative to $SECONDS if you're in a similar situation:

    start=$(date +%s)
    your_command
    seconds=$(($(date +%s) - $start))
    
    0 讨论(0)
  • 2021-02-04 17:46

    This works in Bash, and also Zsh:

    # Set time format to seconds
    TIMEFORMAT=%R
    # Time a process
    PROC_TIME=$(time (insert command here >/dev/null 2>&1) 2>&1)
    echo $PROC_TIME
    
    • The first two redirections hide your process's output ">/dev/null 2>&1"
    • The last redirect is needed because "time" prints the time on stderr
    0 讨论(0)
  • 2021-02-04 17:52

    Using GNU time,

    \time -p -o time.log $COMMAND
    

    and then read time.log.

    (Use either \time or command time, otherwise you'll be using Bash's time built-in, which doesn't support these options.)

    This will work even when $COMMAND prints to stderr (which would confuse Oli's answer), and keeps stdout/stderr (which Farzy's answer doesn't).

    -o ... tells time to send its output to a file rather than to stderr (as is the default), and -p generates the traditional

    real 0.00
    user 0.00
    sys 0.00
    

    rather than GNU time's default of

    0.00user 0.00system 0:00.01elapsed 8%CPU (0avgtext+0avgdata 0maxresident)k
    80inputs+0outputs (1major+188minor)pagefaults 0swaps
    
    0 讨论(0)
  • 2021-02-04 18:00

    Use the time command. Note that the bash version of time is not the same as /usr/bin/time. So you would have something like:

    TIME=`/usr/bin/time --format="%e" your_command_here >/dev/null`
    

    The format just pulls the "real" time value out. You would need to convert that from a string if you wanted to do anything more than display it.

    If you just want to export the string, use export.

    0 讨论(0)
  • 2021-02-04 18:02

    Are you wanting to put this code in your script, or do it from the process that starts the script?

    For the latter, you can use the "time" reserved word and then parse what it returns to get how much time a script takes.

    If you want to do this from within a script you can set the variable SECONDS to zero, and each time thereafter that you reference that variable it will be updated to be the number of elapsed seconds. So, you can put "SECONDS=0" at the very start of your script, and whenever you need the elapsed time it will be in the SECONDS variable.

    You can also use the $SECONDS trick on the command line as well, for example:

    $ SECONDS=0; sleep 5 ; echo "that took approximately $SECONDS seconds"
    

    The time reserved word and the SECONDS variable are both documented in the bash man page.

    0 讨论(0)
提交回复
热议问题