-
Notifications
You must be signed in to change notification settings - Fork 12
/
Copy pathts_batch_upload.py
73 lines (67 loc) · 4.13 KB
/
ts_batch_upload.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
66
67
68
69
70
71
72
73
# -*- coding: utf-8 -*-
#!/usr/bin/python
# March-May 2020 Gwyn Griffiths
# ts_batch_upload.py a program to read in a spots file scraped from wsprnet.org by scraper.sh and upload to a TimescaleDB
# Version 1.2 May 2020 batch upload from a parsed file. Takes about 1.7s compared with 124s for line by line
# that has been pre-formatted with an awk line to be in the right order and have single quotes around the time and character fields
# Added additional diagnostics to identify which part of the upload fails (12 in 1936 times)
import psycopg2 # This is the main connection tool, believed to be written in C
import psycopg2.extras # This is needed for the batch upload functionality
import csv # To import the csv file
import sys # to get at command line argument with argv
import argparse
import logging
# initially set the connection flag to be None
conn=None
connected="Not connected"
cursor="No cursor"
execute="Not executed"
commit="Not committed"
ret_code=0
def ts_batch_upload(batch_file, sql, connect_info):
global conn, connected, cursor, execute, commit, ret_code
try:
with batch_file as csv_file:
csv_data = csv.reader(csv_file, delimiter=',')
# connect to the PostgreSQL database
logging.debug("Trying to connect")
conn = psycopg2.connect(connect_info)
connected = "Connected"
logging.debug("Appear to have connected")
# create a new cursor
cur = conn.cursor()
cursor = "Got cursor"
# execute the INSERT statement
psycopg2.extras.execute_batch(cur, sql, csv_data)
execute = "Executed"
logging.debug("After the execute")
# commit the changes to the database
conn.commit()
commit = "Committed"
# close communication with the database
cur.close()
logging.debug("%s %s %s %s" % (connected, cursor, execute, commit) )
except:
logging.error("Unable to record spot file to the database: %s %s %s %s" % (connected, cursor, execute, commit))
ret_code=1
finally:
if conn is not None:
conn.close()
sys.exit(ret_code)
if __name__ == "__main__":
parser = argparse.ArgumentParser(description='Upload WSPRNET spots to Timescale DB')
parser.add_argument("-i", "--input", dest="spotsFile", help="FILE is a CSV containing WSPRNET spots", metavar="FILE", required=True, nargs='?', type=argparse.FileType('r'), default=sys.stdin)
parser.add_argument("-s", "--sql", dest="sqlFile", help="FILE is a SQL file containing an INSERT query", metavar="FILE", required=True, type=argparse.FileType('r'), default="insert-spots.sql")
parser.add_argument("-a", "--address", dest="address", help="ADDRESS is the hostname of the Timescale DB", metavar="ADDRESS", required=False, default="localhost")
parser.add_argument("-o", "--ip_port", dest="ip_port", help="The IP port of the Timescale DB", metavar="IPPORT", required=False, default="5432")
parser.add_argument("-d", "--database", dest="database", help="DATABASE is the database name in Timescale DB", metavar="DATABASE", required=True, default="wsprnet")
parser.add_argument("-u", "--username", dest="username", help="USERNAME is the username to use with Timescale DB", metavar="USERNAME", required=True, default="wsprnet")
parser.add_argument("-p", "--password", dest="password", help="PASSWORD is the password to use with Timescale DB", metavar="PASSWORD", required=True, default="secret")
parser.add_argument("--log", dest="log", help="The Python logging module's log level to use", type=lambda x: getattr(logging, x), required=False, default=logging.INFO)
args = parser.parse_args()
logging.basicConfig(level=args.log)
with args.sqlFile as sql_file:
sql = sql_file.read().strip()
connect_info="dbname='%s' user='%s' host='%s' port='%s' password='%s'" % (args.database, args.username, args.address, args.ip_port, args.password)
logging.debug(connect_info)
ts_batch_upload(batch_file=args.spotsFile, sql=sql, connect_info=connect_info)