我的编程空间,编程开发者的网络收藏夹
学习永远不晚

python学习.编写查询ip程序

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

python学习.编写查询ip程序

公司服务器上的ip最少的也有100多个,有时候查到一个站的Ip, 不想通过OA去查,自己就用自己最近学的python知识,结合数据库,编写了一python小程序。实现只要输入主ip就能查到这台服务器的子ip,输入子ip能查到此ip所在的主服务器。

功能示例:

使用 -m  参数 指定主服务器地址,即查询此服务器上所有的子ip

使用 -s 参数  指定子ip, 即可查询此子ip所在的服务器主ip地址

使用 -h 或 -help 参数可打印help

使用 -v -version参数可打印版本

如果程序参数不合法,则提示帮助

好了,功能就这么多,我们来看看怎么用python 实现的。

一,我们先看一下数据库,看一下他的结构,其实数据库里很简单,只记录了ip的对应关系。如下图

二,我们来看一下程序是怎么写的先贴一下程序。

 

#! /usr/bin/python

#Filename  select.py

import MySQLdb,os,sys

 

try:

        conn = MySQLdb.connect("localhost","root","密码","ips",charset="utf8")

except MySQLdb.OperationalError, message:

        print "link error"

 

def masterip(ip):

        sql="select secip from ip_master where masterip='%s'" %ip

        cursor=conn.cursor()

        n=cursor.execute(sql)

        cds=cursor.fetchall()

        for cd in cds:

                for col in cd:

                        print "%s" % (col)

        cursor.close()

        conn.close()

 

def secip(ip):

        sql="select masterip from ip_master where secip='%s'" %ip

        cursor=conn.cursor()

        n=cursor.execute(sql)

        cds=cursor.fetchall()

        for cd in cds:

                for col in cd:

                        print "%s" % (col)

        cursor.close()

        conn.close()

 

if len(sys.argv)<2:

        print "You have an error in you syntax,please you -help,-h for help"

        sys.exit()

 

if "-h"==sys.argv[1] or "-help"==sys.argv[1]:

        print '''\

This program select master ips and slave ips.

Options include:

-s  slave ip :use slave ip to select msterip

-m  masterip :use master ip to select slaveip

-h;-help     :help

-v;-version  :prints version '''

        sys.exit()

 

elif "-v"==sys.argv[1] or "-version"==sys.argv[1]:

        print "Version is 0.1"

        sys.exit()

 

elif "-s"==sys.argv[1]:

        if len(sys.argv)<3:

                print "You have an error in you syntax,please you -help,-h for help"

                sys.exit()

        ip=sys.argv[2]

        secip(ip)

 

elif "-m"==sys.argv[1]:

        if len(sys.argv)<3:

                print "You have an error in you syntax,please you -help,-h for help"

                sys.exit()

        ip=sys.argv[2]

        masterip(ip)

 

else:

        print "You have an error in you syntax,please you -help,-h for help"

 

 

 

三.对程序进行解释

#! /usr/bin/python                                 

import MySQLdb,os,sys          #加载 mysqldb  os sys

try:

        conn = MySQLdb.connect("localhost","root","密码","ips",charset="utf8")

except MySQLdb.OperationalError, message:

        print "link error"

 

#尝试利用括号里的信息去连接数据库,如果连接数据库不成功刚打印link error!  

 

def masterip(ip):

        sql="select secip from ip_master where masterip='%s'" %ip

        cursor=conn.cursor()

        n=cursor.execute(sql)

        cds=cursor.fetchall()

        for cd in cds:

                for col in cd:

                        print "%s" % (col)

        cursor.close()

        conn.close()

 

定义一个masterip函数, 括号里的ip 为参数,在下面的sql语句里用到。sql后面是查询语句。 利用上面括号里定义的ip 去查询 子ip。再利用for 循环逐个打印出ip!

 

def secip(ip):

        sql="select masterip from ip_master where secip='%s'" %ip

        cursor=conn.cursor()

        n=cursor.execute(sql)

        cds=cursor.fetchall()

        for cd in cds:

                for col in cd:

                        print "%s" % (col)

        cursor.close()

        conn.close()

 

定义一个secip函数, 括号里的ip 为参数,在下面的sql语句里用到。sql后面是查询语句。 利用上面括号里定义的ip 去查询 主ip。再利用for 循环逐个打印出ip!

 

if len(sys.argv)<2:

        print "You have an error in you syntax,please you -help,-h for help"

        sys.exit()

 

判断命令行参数,如果命令行参数小于2,(命令本身就属于一个参数)就打印提示信息,并退出,此行的意思就是半数命令后面有没有跟参数,如果没有跟参数,就直接退出。

 

if "-h"==sys.argv[1] or "-help"==sys.argv[1]:

        print '''\

This program select master ips and slave ips.

Options include:

-s  slave ip :use slave ip to select msterip

-m  masterip :use master ip to select slaveip

-h;-help     :help

-v;-version  :prints version '''

        sys.exit()

 

#判断命令行第一个数据是不是 -h (注,命令行参数是从0开始,也就是命令本身),如果是 -h的话,就打印帮助信息,并退出。

 

elif "-v"==sys.argv[1] or "-version"==sys.argv[1]:

        print "Version is 0.1"

        sys.exit()

 

#判断命令行第一个数据是不是 -v (注,命令行参数是从0开始,也就是命令本身),如果是 -v的话,就打印版本信息,并退出。

 

elif "-s"==sys.argv[1]:

        if len(sys.argv)<3:

                print "You have an error in you syntax,please you -help,-h for help"

                sys.exit()

        ip=sys.argv[2]

        secip(ip)

 

#判断命令行第一个数据是不是 -s (注,命令行参数是从0开始,也就是命令本身),如果是 -s的话,判断命令行参数是否小于3,也就是 -s 后面有没有跟参数(ip), 如果没跟的话,就打印提示信息,并退出 。如果跟了的话,就把-s 后面的参数给 ip这个变量,并执行 secip() 这个函数。

 

elif "-m"==sys.argv[1]:

        if len(sys.argv)<3:

                print "You have an error in you syntax,please you -help,-h for help"

                sys.exit()

        ip=sys.argv[2]

        masterip(ip)

 

#判断命令行第一个数据是不是 -m (注,命令行参数是从0开始,也就是命令本身),如果是 -m的话,判断命令行参数是否小于3,也就是 -m 后面有没有跟参数(ip), 如果没跟的话,就打印提示信息,并退出 。如果跟了的话,就把-m 后面的参数给 ip这个变量,并执行 masterip() 这个函数。

 

else:

        print "You have an error in you syntax,please you -help,-h for help"

 

如果跟上面所有的参数都不符合,就直接打印帮助信息。

 

 

Ok!程序完了。很简单,但好像也很实用。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

python学习.编写查询ip程序

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

python学习.编写查询ip程序

公司服务器上的ip最少的也有100多个,有时候查到一个站的Ip, 不想通过OA去查,自己就用自己最近学的python知识,结合数据库,编写了一python小程序。实现只要输入主ip就能查到这台服务器的子ip,输入子ip能查到此ip所在的主服
2023-01-31

python学习之编写查询ip程序

公司服务器上的ip最少的也有100多个,有时候查到一个站的Ip, 不想通过OA去查,自己就用自己最近学的python知识,结合数据库,编写了一python小程序。实现只要输入主ip就能查到这台服务器的子ip,输入子ip能查到此ip所在的主服
2022-06-04

Python的爬虫程序编写框架Scrapy入门学习教程

1. Scrapy简介 Scrapy是一个为了爬取网站数据,提取结构性数据而编写的应用框架。 可以应用在包括数据挖掘,信息处理或存储历史数据等一系列的程序中。 其最初是为了页面抓取 (更确切来说, 网络抓取 )所设计的, 也可以应用在获取A
2022-06-04

学习python之编写简单简单连接数据库并执行查询操作

python 连接数据库操作, 方法如下: 在本机的mysql 数据库中有一个名为yao的库,其中有一个名为user的表,表中的内容如图下面,则是python连接数据库的方法,及查找出表中的内容,代码如下:#! /usr/bin/pytho
2022-06-04

Python学习教程:成语查询工具 - 数据获取

Python学习教程:成语查询工具 - 数据获取我们从这个网站上获取想要的内容,不用考虑太多的板块,直接按照字母检索即可
2023-06-02

0基础用android做一个excel表查询器(2):编写程序

0基础用android做一个Excel表查询器(2):编写程序 编完页面下面就该开始写程序了,首先确定一下思路,很简单,将Excel表写入一个List(或数组)里,然后获取Plain Text中写入的内容,然后与List里的内容进行比对,发
2022-06-06

如何通过C++编写一个简单的天气查询程序?

在这个数字化时代,天气预报已经成为了我们生活中的重要组成部分之一。通过天气预报,我们能够了解到未来天气的变化,从而做好相应的准备。而现今,天气查询程序也已经成为了我们日常生活中的重要工具之一。如果您想学习如何通过编程语言来创建一个简单的天气
如何通过C++编写一个简单的天气查询程序?
2023-11-03

学习如何使用Golang中的流程控制语句编写高效的程序

学习如何使用Golang中的流程控制语句编写高效的程序,需要具体代码示例Golang 是一门强大而高效的编程语言,相较于其他语言,它提供了一些独特而强大的流程控制语句,使得我们能够编写出更高效的程序。在本文中,我们将探讨一些常见的流程控制语
学习如何使用Golang中的流程控制语句编写高效的程序
2023-12-23

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录