美文网首页
python字符串截取操作

python字符串截取操作

作者: 夏洛克里莫 | 来源:发表于2017-09-13 15:56 被阅读0次

        由于开发需要,大部分时间都是用java来实现需求的,但是由于对python的喜爱,岂是这种程度的事情所能阻止的,因此在闲余之际,还是想要用python来搞一些事情的,闲话就到此为止。
        在最近的需求中,我需要对IP地址进行处理获取网络号和主机号(默认C类IP地址)。
        python中对字符串进行操作可以有正则表达式和切片可供使用,对应java中的是正则表达式和substring。

    代码1:
    >ip = "192.168.0.1"
    

    首先是截取网络号,正则代码如下:

    代码2:
    >networkNum = re.match(r"(\d+\.){2}(\d+)",ip).group()
    
    
    

    切片代码:

    代码3:
    >networkNum = ip[0:ip.rindex('.')]
    

    获取主机号,正则代码:

    代码4:
    >strinfo = re.compile(r"(\d+\.){3}")
    >hostNum = strinfo.sub('',ip)
    >or:
    >hostNum = re.sub(r"(\d+\.){3}","",ip)
    

        当然用正则表达式获取主机号还有replace方法,但是到写这篇博客的时候我还没研究出如何用replace来获取主机号。

    切片代码:

    代码5:
    > hostNum = ip[ip.rindex('.')+1:]
    

        从上边的代码中已经看出切片在截取字符串上的强大了,完全一句话就可以搞定,但是其中确实有一些坑存在的。
        首先:在代码5中,需要获取IP最后一段的值,在最开始我写的是:

    > hostNum = ip[ip.rindex('.')+1:-1]
    

        这样的结果是我没有获取到主机号,再仔细研究一下切片后发现切片所适用的数学表达式是 “[ )”,也就是前边的包含的,而后边是不包含的(自幼数学不好,不知道该怎么用专业的方法表述),这个错误可是非常低级,但却又是非常致命的,毕竟 这东西是不会报错的!不会报错的!不会报错的!所以在日常使用中选好方法,做好备注!做好备注!做好备注!,当然这只是在提醒我自己,毕竟我才是小菜鸡。

    相关文章

      网友评论

          本文标题:python字符串截取操作

          本文链接:https://www.haomeiwen.com/subject/exqlsxtx.html