首页 > 数据库技术 > 详细

Python MAC地址 获取,过滤,转换 Python MYSQL 数据获取,比较

时间:2015-11-24 18:45:17      阅读:375      评论:0      收藏:0      [点我收藏+]


【输出MAC 地址】

[root@pc0003 glpi_switch_ocs]# cat huawei 
#!/usr/bin/expect -f
set ip 192.168.AC.IP
set password AC.PASSWORD
set timeout 1
spawn ssh AC.USER@$ip
expect {
  "*yes/no" { send "yes\r"; exp_continue}
  "*password:" { send "$password\r" }
   }
expect "<ac001>"
send "sys\r"
expect "\[ac001\]"
send "wlan\r"
expect "wlan-view"
send "sta-whitelist-profile id 1\r"
expect "prof-vobile"
send "d th\r"
expect "More"
send "\t"
expect "More"
send "\t"
expect "More"
send "\t"
expect "More"
send "\t"
expect "More"
send "\t"
expect eof
#interact
[root@pc0003 glpi_switch_ocs]#




【过滤MAC地址】

[root@pc0003 glpi_switch_ocs]# cat 1get.switch.wlan.grep.mac.sh 
#!/bin/bash
# 此脚本正则匹配MAC,输出原格式的纯MAC地址
#指定分割符
split="-"
mkdir tmp > /dev/null 2>&1
./huawei |grep "sta-mac" > ./tmp/huawei.mac.txt
stat=`echo $?`
if [ $stat==0 ]
then
    echo "已获取到交换机mac白名单"
else
    echo "与交换机联络失败"
fi
#1a?2b?3d?4g?5k?6h
#cat mac.txt | egrep -o "([0-9a-fA-F]{2})(([/\s$split][0-9a-fA-F]{2}){5})" > mac.txt
#1qaz?2wsx?3edc
cat ./tmp/huawei.mac.txt | egrep -o "([0-9a-fA-F]{4})(([/\s$split][0-9a-fA-F]{4}){2})" > ./tmp/grep.switch.mac.txt
stat=`echo $?`
if [ $stat==0 ]
then
echo "纯MAC地址文件已经输出: ./tmp/grep.switch.mac.txt"
echo "格式如下"
head ./tmp/grep.switch.mac.txt
fi





【MAC地址转换】

#!/usr/bin/python
new1=open(‘./tmp/convert.switch‘,‘w‘)
import re
import os
r1=r"\w\w\w\w-\w\w\w\w-\w\w\w\w"
for i in open(‘./tmp/grep.switch.mac.txt‘):
    str_upper=i.upper()
    string1=str(re.findall(r1,str_upper))
    list1=list(string1)
    while ‘[‘ in list1:
        list1.remove(‘[‘)
    while ‘\‘‘ in list1:
        list1.remove(‘\‘‘)
    while ‘-‘ in list1:
        list1.remove(‘-‘)
    while ‘]‘ in list1:
        list1.remove(‘]‘)
    new1.write(list1[0]+list1[1]+":"+list1[2]+list1[3]+":"+list1[4]+list1[5]+":"+list1[6]+list1[7]+":"+list1[8]+list1[9]+":"+list1[10]+list1[11]+"\n")
new1.close()




【获取GLPI的MAC地址】

[root@pc0003 glpi_switch_ocs]# cat 3get.glpi.sh 
#!/bin/bash
# 此脚本正则匹配MAC,输出原格式的纯MAC地址
mkdir tmp > /dev/null 2>&1
#指定分割符
split=":"
mysql -h 192.168.GLPI.MYSQL.IP -pGLPI.MYSQL.PASSWORD  -Ne "use glpi;select glpi_items_devicenetworkcards.mac from glpi_items_devicenetworkcards,glpi_devicenetworkcards  where glpi_items_devicenetworkcards.devicenetworkcards_id = glpi_devicenetworkcards.id;" > tmp/glpi.all.mac
stat=`echo $?`
if [ $stat==0 ]
then
    echo "已获取到glpi的mac所有清单"
else
    echo "与mysql联络失败!"
fi
#1a?2b?3d?4g?5k?6h
cat tmp/glpi.all.mac | egrep -o "([0-9a-fA-F]{2})(([/\s$split][0-9a-fA-F]{2}){5})" > tmp/grep.glpi.mac.txt
stat=`echo $?`
if [ $stat==0 ]
then
echo "纯MAC地址文件已经输出:./tmp/grep.glpi.mac.txt"
echo "格式如下"
head ./tmp/grep.glpi.mac.txt
fi



[MAC地址转换]

#!/usr/bin/python
new1=open(‘./tmp/convert.glpi.mac‘,‘w‘)
import re
r1=r"\w\w:\w\w:\w\w:\w\w:\w\w:\w\w"
for i in open(‘tmp/grep.glpi.mac.txt‘):
    str_upper=i.upper()
    string1=str(re.findall(r1,str_upper))
    list1=list(string1)
    while ‘[‘ in list1:
        list1.remove(‘[‘)
    while ‘\‘‘ in list1:
        list1.remove(‘\‘‘)
    while ‘:‘ in list1:
        list1.remove(‘:‘)
    while ‘]‘ in list1:
        list1.remove(‘]‘)
    print list1
    new1.write(list1[0]+list1[1]+":"+list1[2]+list1[3]+":"+list1[4]+list1[5]+":"+list1[6]+list1[7]+":"+list1[8]+list1[9]+":"+list1[10]+list1[11]+"\n")
new1.close()


本文出自 “折腾岁月。” 博客,谢绝转载!

Python MAC地址 获取,过滤,转换 Python MYSQL 数据获取,比较

原文:http://990487026.blog.51cto.com/10133282/1716406

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!