对从mysql读取的数据进行合规性检测

假设编写一个登录交换机的脚本,登录交换机时,交换要求输入账号、密码及enable(super)密码,而用于登录交换机所需要的信息至少需包括:交换机IP、登录账号、密码及enable(super)密码,这些信息均存在mysql数据库中。脚本需从数据库中读取该信息。所以读取的数据交换机IP、登录账号、密码及enable(super)密码均不能为空。如果为空,则登录交换机肯定失败,无需再执行后面的登录代码了。所以有必要对从数据库中读取的数据做合规性检测。

现数据库中的信息如下:

mysql> select * from TSwitch;
+--------------+----------+----------+----------------+
| IP           | Username | Password | EnablePassword |
+--------------+----------+----------+----------------+
| 192.168.0.80 | admin    | cisco    | cisco          |
| 192.168.0.70 | admin    | H3c      | NULL           |
| 192.168.0.60 | NULL     | huawei   | huawei         |
+--------------+----------+----------+----------------+

从上标可看出,只有第一行的数据是合规的。第二数据的EnablePassword值为空、第三行数据的Username为空,所以数据不合规,如何进行检测。

[root@localhost python]# cat chkparavalid.py 
#!/usr/bin/env python
#encoding=utf-8
import MySQLdb

def argisvalid(mytuple):
    "return 0 if the mylist including Null"
    myres=1
    for m in mytuple:
        if m==None:
            myres=0
            continue
    return myres

def main():
    conn= MySQLdb.connect(
        host='localhost',
        port = 3306,
        user='root',
        passwd='123456',
        db ='mydb',
        )
    cur = conn.cursor()
    sqlstr1=cur.execute("select IP,Username,Password,EnablePassword from TSwitch");
    sqlset1=cur.fetchmany(sqlstr1)
    for sqlres1 in sqlset1:
        print argisvalid(sqlres1)
    cur.close()
    conn.commit()
    conn.close()

if __name__=='__main__':
    main()
上面代码执行的结果是,如果数据不合规,则输出0,合规则输出1.

[root@localhost python]# python chkparavalid.py 
1
0
0

该脚本的关键函数为argisvalid,作用为参数(list或tuple)中如果含None值则返回0,否则返回1。



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值