-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathmain.py
executable file
·65 lines (50 loc) · 1.89 KB
/
main.py
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
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
#! /usr/bin/env python
import os
import sqlite3
from utils import parse_ldb
from db_helper import initialize, get_database_file, fetch_addresses_from_database, add_address
from arguments_parser import get_arguments
from csv_helper import write_to_csv
def get_all_txs(arguments):
return parse_ldb(
fin_name=arguments.chainstate,
version=arguments.bitcoin_version,
types={0, 1}
)
def in_memory(arguments):
address_dict = dict()
for address, amount, height in get_all_txs(arguments):
if address in address_dict:
address_dict[address][0] += amount
address_dict[address][1] = height
else:
address_dict[address] = [amount, height]
for key in address_dict.iterkeys():
row = address_dict[key]
yield key, row[0], row[1]
def with_sqlite(arguments):
database_file = get_database_file(arguments)
with sqlite3.connect(database_file) as database:
cursor = initialize(database)
for address, amount, height in get_all_txs(arguments):
add_address(address, amount, height, cursor)
database.commit()
fetch_addresses_from_database(cursor, arguments)
for result in cursor:
yield result[0], result[1], result[2]
database.commit()
cursor.close()
if __name__ == '__main__':
args = get_arguments()
print('Reading BTC chainstate from [' + args.chainstate + ']')
if args.database:
print('Storing transactions in SQLite database [' + args.database + ']')
address_iterator = with_sqlite(args)
else:
print('Running everything in-memory')
address_iterator = in_memory(args)
if args.outputFile:
print('Saving output to [' + args.outputFile + ']')
write_to_csv(address_iterator, args.outputFile)
else:
print('Not yet implemented printing to stdout')