python取MYSQL数据库里的IP来PING,将结果再写到数据库中,但是第二次再取IP时便出错,取出来是空的 30
#_*_coding:utf-8_*_importMySQLdbasmdbimportsysimportosimportthreadingconn=mdb.connect...
# _*_ coding:utf-8 _*_
import MySQLdb as mdb
import sys
import os
import threading
conn = mdb.connect('localhost','root','root','test');
with conn:
cur = conn.cursor(mdb.cursors.DictCursor)
cur.execute("SELECT hostIP,id,status_id FROM website_serverhost")
rows = cur.fetchall()
for row in rows:
print "%s %s" % (row["id"],row["hostIP"])
data = os.system("ping -c 1 %s>/dev/null 2>&1" % row["hostIP"])
if data == 0:
print "%s:正常" % row["hostIP"]
cur.execute("INSERT INTO testrecord(hostIP, status) VALUES ('%s',1)"% row["hsotIP"])
else:
print "%s:中断" % ip
附报错信息:
Traceback (most recent call last):
File "pingServerHost.py", line 25, in <module>
cur.execute("INSERT INTO testrecord(hostIP, status) VALUES ('%s',1)"% row["hsotIP"])
KeyError: 'hsotIP' 展开
import MySQLdb as mdb
import sys
import os
import threading
conn = mdb.connect('localhost','root','root','test');
with conn:
cur = conn.cursor(mdb.cursors.DictCursor)
cur.execute("SELECT hostIP,id,status_id FROM website_serverhost")
rows = cur.fetchall()
for row in rows:
print "%s %s" % (row["id"],row["hostIP"])
data = os.system("ping -c 1 %s>/dev/null 2>&1" % row["hostIP"])
if data == 0:
print "%s:正常" % row["hostIP"]
cur.execute("INSERT INTO testrecord(hostIP, status) VALUES ('%s',1)"% row["hsotIP"])
else:
print "%s:中断" % ip
附报错信息:
Traceback (most recent call last):
File "pingServerHost.py", line 25, in <module>
cur.execute("INSERT INTO testrecord(hostIP, status) VALUES ('%s',1)"% row["hsotIP"])
KeyError: 'hsotIP' 展开
1个回答
展开全部
这个问题相当好解决啊。你在插数据的时候,是不是定义了ID,让ID自动增加就可以实现添加而不是覆盖。
设计数据库表的时候,第一个字段ID让它自增方式。在python写insert语句时,勉强将你自己定义的ID值放进去。就是insert table () values() 前面那个括号里不要写ID,后面values也将ID值去掉
设计数据库表的时候,第一个字段ID让它自增方式。在python写insert语句时,勉强将你自己定义的ID值放进去。就是insert table () values() 前面那个括号里不要写ID,后面values也将ID值去掉
追问
那个不是ID,是主机状态断开还是连通,而且这不是插入数据库的问题,是在第二次读取IP发生错误,我测试过如果在FOR中不执行插入数据库的操作是可以正常读取数据库中每条信息,这里的问题应该是进行一次插入数据后和之前读出来的发生冲突了,但是具体如何解决我就不清楚了,我是新手。
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询