本篇內(nèi)容介紹了“Python怎么關(guān)閉warning信息提示”的有關(guān)知識,在實(shí)際案例的操作過程中,不少人都會(huì)遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!
站在用戶的角度思考問題,與客戶深入溝通,找到秀峰網(wǎng)站設(shè)計(jì)與秀峰網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗(yàn),讓設(shè)計(jì)與互聯(lián)網(wǎng)技術(shù)結(jié)合,創(chuàng)造個(gè)性化、用戶體驗(yàn)好的作品,建站類型包括:成都做網(wǎng)站、成都網(wǎng)站建設(shè)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣、域名注冊、虛擬空間、企業(yè)郵箱。業(yè)務(wù)覆蓋秀峰地區(qū)。
背景
在使用 python MySQLdb 執(zhí)行sql 命令的時(shí)候,如果執(zhí)行結(jié)果含有warning,則會(huì)被寫入到 stderr 展示到終端命令行。其實(shí)這些warning提示信息沒有任何實(shí)際的作用。
root@rac3:~/scripts# >python set_ms.py -m 10.0.2.15:3306 -s 10.0.2.6:3308
Begin to set Replicate on slave 10.0.2.6:3308
set_ms.py:35: Warning: Slave already has been stopped
ret=cursor.execute(SQL)
set_ms.py:35: Warning: Sending passwords in plain text without SSL/TLS is extremely insecure.
ret=cursor.execute(SQL)
set_ms.py:35: Warning: Storing MySQL user name or password information in the master info repository is not secure and is therefore not recommended. Please consider using the USER and PASSWORD connection options for START SLAVE; see the 'START SLAVE Syntax' in the MySQL Manual for more information.
ret=cursor.execute(SQL)
Success : CHANGE MASTER TO MASTER_HOST='10.0.2.15',MASTER_USER='slave',MASTER_PASSWORD='xxxx',MASTER_PORT=3306,MASTER_LOG_FILE='mysql-bin.000002', MASTER_LOG_POS=314;
那我們該怎么解決呢?
Python 提供了warnings模塊,通過該模塊控制系統(tǒng)warning 的輸出形式,關(guān)閉或者打開。舉個(gè)例子
1 將 MySQLdb.Warning warnings 傳入exceptions 以便通過 try catch 獲取exception 進(jìn)而對其進(jìn)行業(yè)務(wù)邏輯處理。
filterwarnings('error', category=MySQLdb.Warning)
如果設(shè)置為error 則需要在代碼中引入 except機(jī)制
try:
execSQL ...
except MySQLdb.Warning, e:
print "MySQLdb Warning", e
2 設(shè)置為warning 為 ignore ,忽略所有warning 信息。
filterwarnings('ignore', category = MySQLdb.Warning)
代碼實(shí)現(xiàn)
import MySQLdb
import MySQLdb.cursors
from warnings import filterwarnings
filterwarnings('ignore', category = MySQLdb.Warning)
def execSql(SQL,IP,PORT,USER,PWD):
'''####exec_sql####'''
try:
db=MySQLdb.connect(host=IP,user=USER,passwd=PWD,db='test',port=int(PORT),charset="utf8")
cursor=db.cursor(cursorclass=MySQLdb.cursors.DictCursor)
except MySQLdb.Error,e:
print "connection failed!Error %d:%s"%(e.args[0],e.args[1])
sys.exit(9)
“Python怎么關(guān)閉warning信息提示”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!