Python中strip方法的妙用

时间:2021-04-06 15:12:16

【开胃小菜】

当提到python中strip方法,想必凡接触过python的同行都知道它主要用来切除空格。有下面两种方法来实现。

方法一:用内置函数

#<python>

if __name__ == '__main__':

str = ' Hello world '

print '[%s]' %str.strip()

#</python>

方法二:调用string模块中方法

#<python>

import string

if __name__ == '__main__':

str = ' Hello world '

print '[%s]' %string.strip(str)

#</python>

不知道大家是否知道这两种调用有什么差别?下面是个人一些看法

Ø  str.strip()是调用python的内置函数,string.strip(str)是调用string模块中的方法

Ø  string.strip(str)是在string模块定义的。而str.strip()是在builtins模块中定义的

问题一: 怎样查看一个模块中方法是否在内置模块有定义?

用dir(模块名)看是否有'__builtins__'属性。

比如:查看string模块

#<python> print dir(string)
#</python>

问题二、怎样查看python中全部的内置函数

#<python>

print dir(sys.modules['__builtin__'])

#</python>

问题三、怎样查看内置模块中内置函数定义

#<python> print help(__builtins__) 
#</python>

以上一些都是大家平时都知道的,接下来就进入本文的主题:

 

【饭中硬菜】

首先请大家看一下下列程序的执行结果:

#<python>

if __name__ == '__main__':

str = 'hello world'

print str.strip('hello')

print str.strip('hello').strip()

print str.strip('heldo').strip()   
#sentence 1

stt = 'h1h1h2h3h4h'

print stt.strip('h1')               
#sentence 2

s ='123459947855aaaadgat134f8sfewewrf7787789879879'

print s.strip('0123456789')        
#sentence 3

#</python>

结果见下页:

执行结果:

world

world

wor

2h3h4

aaaadgat134f8sfewewrf

你答对了吗?O(∩_∩)O~

假设你都答对了,在此处我奉上32个赞 …

结果分析:

首先我们查看一下string模块中的strip源代码:

#<python>

# Strip leading and trailing tabs and spaces

def strip(s, chars=None):

"""strip(s [,chars]) -> string

    Return a copy of the string swith leading and trailing

    whitespace removed.

    If chars is given and not None,remove characters in chars instead.

    If chars is unicode, S will beconverted to unicode before stripping.

    """

returns.strip(chars)

#</python>

冒昧的翻译一下: 该方法用来去掉首尾的空格和tab。返回一个去掉空格的S字符串的拷贝。假设參数chars不为None有值,那就去掉在chars中出现的全部字符。假设chars是unicode,S在操作之前先转化为unicode.

以下就上面里子中的sentence1 \2 \3做个说明:

#<python>

str = 'hello world'

print str.strip('heldo').strip()

#</python>

result:wor

运行步骤:

elloworld

lloworld

oworld

oworl

worl

wor

wor

详细代码运行流程:

#<python>

print str.strip('h')

print str.strip('h').strip('e')

print str.strip('h').strip('e').strip('l')

print str.strip('h').strip('e').strip('l').strip('d')

print str.strip('h').strip('e').strip('l').strip('d').strip('o')

print str.strip('h').strip('e').strip('l').strip('d').strip('o').strip('l')

printstr.strip('h').strip('e').strip('l').strip('d').strip('o').strip('l').strip()

#</python>

不知道你是否看懂当中的奥妙,我是在项目经理陕奋勇帮助下,一起才发现这个规律。

如今略微总结一下:

s.strip(chars)使用规则:

首先遍历chars中的首个字符。看看在S中是否处于首尾位置,假设是就去掉。把去掉后的新字符串设置为s,继续循环,从chars中的首个字符開始。假设不在。直接从chars第二个字符開始。一直循环到,s中首尾字符都不在chars中。则循环终止。

关键点:查看chars中字符是否在S中首尾

看完这种方法发现python源代码开发者太牛X了,这么经典算法都想的出。

【饭后糕点】

这种方法主要应用于依照特定规则去除两端的制定字符。假设sentence3就是个非常好的应用。

比如: 截取字符串中两端数字。或者获取特性字符第一次和最后一次出现之间的字符串等等。