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'
展开
 我来答
dgrassx
2016-08-04 · TA获得超过400个赞
知道小有建树答主
回答量:295
采纳率:0%
帮助的人:156万
展开全部
这个问题相当好解决啊。你在插数据的时候,是不是定义了ID,让ID自动增加就可以实现添加而不是覆盖。

设计数据库表的时候,第一个字段ID让它自增方式。在python写insert语句时,勉强将你自己定义的ID值放进去。就是insert table () values() 前面那个括号里不要写ID,后面values也将ID值去掉
追问
那个不是ID,是主机状态断开还是连通,而且这不是插入数据库的问题,是在第二次读取IP发生错误,我测试过如果在FOR中不执行插入数据库的操作是可以正常读取数据库中每条信息,这里的问题应该是进行一次插入数据后和之前读出来的发生冲突了,但是具体如何解决我就不清楚了,我是新手。
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式