Как записать в файл при сбое подключения к БД - PullRequest
0 голосов
/ 28 апреля 2018

У меня есть приведенный ниже скрипт на Python, и он работает очень хорошо, но я хотел бы представить некоторые отказоустойчивые опции.

1) если я не могу найти (в этом примере) Майкла, я хотел бы записать в файл ОШИБКА ..

2) Если база данных не позволяет мне подключиться по какой-либо причине, я хотел бы записать в другой файл CONNECTION_ERROR

Вот мой сценарий:

#! /usr/bin/python

import pymssql

import sys
sys.path.insert(0, '/opt/mount/safe')
from secrets import password

conn = pymssql.connect(
server="server",
port=port,
user="user",
password=password,
database="database")
conn

cursor = conn.cursor()
cursor.execute("SELECT name, address FROM database WHERE name = 'michael'")
with open('safe/file.txt', 'w') as f:
     for row in cursor.fetchall():
        print ( "Person " + (row[0])),
        print ( "has this address " + (row[1]))
        f.write(str( "Person " + (row[0])))
        f.write("%s\n" % str( " has this address " + (row[1])))
conn.close()

1 Ответ

0 голосов
/ 02 мая 2018

Это заняло у меня некоторое время, но приведенное ниже работает очень хорошо

import sys, pymssql, string, os, calendar, datetime, traceback, socket, platform

try:
        d = datetime.datetime.now()
        log = open("LogFile.txt","a")
        log.write("----------------------------" + "\n")
        log.write("----------------------------" + "\n")
        log.write("Log: " + str(d) + "\n")
        log.write("\n")
# Start process...
        starttime = datetime.datetime.now()
        log.write("Begin process:\n")
        log.write("     Process started at "
        + str(starttime) + "\n")
        log.write("\n")

xxxxxx 

CODE HERE

XXXXXX



        endtime = datetime.datetime.now()
# Process Completed...
        log.write("     Completed successfully in "
        + str(endtime - starttime) + "\n")
        log.write("\n")
        log.close()
except:
        tb = sys.exc_info()[2]
        tbinfo = traceback.format_tb(tb)[0]
# Concatenate information together concerning
# the error into a message string
        pymsg = "PYTHON ERRORS:\nTraceback info:\n" + tbinfo + "\nError Info:\n" + str(sys.exc_info())
# Return python error messages for use in
# script tool or Python Window
        log.write("" + pymsg + "\n")
        log.close()
...