-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathbtc-blk-conf-times.py
More file actions
50 lines (42 loc) · 1.85 KB
/
btc-blk-conf-times.py
File metadata and controls
50 lines (42 loc) · 1.85 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
#!/usr/bin/python3
import json
import subprocess
import sys
import datetime
blockchainCLI = 'bitcoin-cli'
confirmTimes = []
try:
blockCount = int(sys.argv[1])
except IndexError:
blockCount = 1
countProc = subprocess.Popen( [blockchainCLI, 'getblockcount'],
stdout=subprocess.PIPE )
blockHeight = int(countProc.stdout.read().decode('utf-8'))
def getBlockConfirmTime(blockNum):
hashProc = subprocess.Popen( [blockchainCLI, 'getblockhash', str(blockNum)],
stdout=subprocess.PIPE )
blockHash = hashProc.stdout.read().decode('utf-8')
blockProc = subprocess.Popen( [blockchainCLI, 'getblock', blockHash],
stdout=subprocess.PIPE )
blockData = blockProc.stdout.read().decode('utf-8')
block = json.loads(blockData)
blockConfirmTimestamp = int(block['time'])
return blockConfirmTimestamp
for block in range(blockCount):
currentBlockTime = getBlockConfirmTime(blockHeight - block)
previousBlockTime = getBlockConfirmTime(blockHeight - block - 1)
timeToConfirmSec = currentBlockTime - previousBlockTime
confirmTimes.append(timeToConfirmSec)
timeToConfirmBlock = str(datetime.timedelta(
seconds=(timeToConfirmSec)))
blockConfirmTime = datetime.datetime.fromtimestamp(
currentBlockTime).strftime('%m-%d-%Y %H:%M:%S')
print('-----------------------------------------')
print("Block %d" % (blockHeight - block,))
print("Block Confirmed at: %s" % (blockConfirmTime,))
print("Time to Confirm Block: %s" % (timeToConfirmBlock,))
print('-----------------------------------------')
if blockCount > 1:
avgConfirmTime = sum(confirmTimes) / blockCount
formattedAvg = str(datetime.timedelta(seconds=avgConfirmTime))
print("\nAverage Time to Confirm Block: %s" % (formattedAvg,))