-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathdbCore.py
More file actions
66 lines (51 loc) · 2.16 KB
/
Copy pathdbCore.py
File metadata and controls
66 lines (51 loc) · 2.16 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
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
import sys
import os
import platform
import numpy as np
import pandas as pd
import pyodbc
import pandas.io.sql as sql
sys.path.append('login')
import credentials as cr
def dbConnect(server,db='Opedia', TDS_Version='7.3'):
if server == 'Rainier':
usr=cr.usr_rainier
psw=cr.psw_rainier
ip=cr.ip_rainier
port = cr.port_rainier
else:
usr=cr.usr_beast
psw=cr.psw_beast
ip=cr.ip_beast
port = cr.port_beast
server = ip + ',' + port
if platform.system().lower().find('windows') != -1:
conn = pyodbc.connect('DRIVER={SQL Server};SERVER=' + server + ';DATABASE=' + db + ';Uid=' + usr + ';Pwd='+ psw )
elif platform.system().lower().find('darwin') != -1:
conn = pyodbc.connect('DRIVER=/usr/local/lib/libtdsodbc.so;SERVER=' + server + ';DATABASE=' + db + ';Uid=' + usr + ';Pwd='+ psw )
elif platform.system().lower().find('linux') != -1:
conn = pyodbc.connect(DRIVER='/usr/lib/x86_64-linux-gnu/odbc/libtdsodbc.so', TDS_Version = TDS_Version , server = ip , port = port, uid = usr, pwd = psw)
return conn
def dbExecute(sql, vals):
conn = dbConnect()
cursor = conn.cursor()
#vals = nanToNone(vals)
cursor.execute(sql, vals)
conn.commit()
return
def dbRead(query,server):
conn = dbConnect(server)
dframe = sql.read_sql(query, conn)
conn.close()
return dframe
def bulkInsert(filePath, tableName, determinator=',', usr='ArmLab', psw='ArmLab2018', ip='128.208.239.15', port='1433', db='Opedia', TDS_Version='7.3'):
conn = dbConnect(usr=usr, psw=psw, ip=ip, port=port, db=db, TDS_Version=TDS_Version)
cursor = conn.cursor()
query = "BULK INSERT %s FROM '%s' WITH ( FIELDTERMINATOR = '%s', ROWTERMINATOR = '\n', FIRSTROW = 2 ) " % (tableName, filePath, determinator)
cursor.execute(query, [])
conn.commit()
return
def bcpInsert(filePath, tableName, determinator=',', usr='ArmLab', psw='ArmLab2018', ip='128.208.239.15', port='1433', db='Opedia', TDS_Version='7.3'):
str = """bcp """ + db + """.dbo.""" + tableName + """ in """ + filePath + """ -e error -c -t, -U """ + usr + """ -P """ + psw + """ -S """ + ip + ""","""+ port
os.system(str)
# print('BCP insert finished')