1,in和not in

 


 
  
  1. yuan@ThinkPad-SL510:~$ ipython -nobanner 
  2.  
  3. In [1]: uname = "Linux #50-Ubuntu SMP Fri Mar 18 19:00:26 UTC 2011" 
  4.  
  5. In [2]: 'Linux' in uname 
  6. Out[2]: True 
  7.  
  8. In [3]: 'Darwin' in uname 
  9. Out[3]: False 
  10.  
  11. In [4]: 'Darwin' not in uname 
  12. Out[4]: True 
 2,find()和index()
 

 
  
  1. In [5]: uname.index('Linux'
  2. Out[5]: 0 
  3.  
  4. In [6]: uname.find('Linux'
  5. Out[6]: 0 
  6.  
  7. In [7]: uname.index('Darwin'
  8. --------------------------------------------------------------------------- 
  9. ValueError                                Traceback (most recent call last) 
  10.  
  11. /home/yuan/<ipython console> in <module>() 
  12.  
  13. ValueError: substring not found 
  14. #错误很明显呢,小看读者的智商了,有没有?呵呵 
  15.  
  16. In [8]: uname.find('Darwin'
  17. Out[8]: -1 
  18. #如果find成功返回第一个字符的index,如果find失败则返回 -1  
  19.  
  20. In [9]: smp_index = uname.index('SMP'
  21.  
  22. In [10]: smp_index 
  23. Out[10]: 17 
  24. In [11]: uname[smp_index:] 
  25. Out[11]: 'SMP Fri Mar 18 19:00:26 UTC 2011' 
  26.  
  27. In [12]: uname[:smp_index] 
  28. Out[12]: 'Linux #50-Ubuntu ' 
  29. #很熟悉吧?切片操作 
  30. #语法:string[index:] 
  31.  
  32. In [13]: uname 
  33. Out[13]: 'Linux #50-Ubuntu SMP Fri Mar 18 19:00:26 UTC 2011' 
3,startswith()和endswith()
 

 
  
  1. yuan@ThinkPad-SL510:~$ ipython -nobanner 
  2.  
  3. In [1]: some_string = "Gao-yuan is good" 
  4.  
  5. In [2]: some_string.startswith("Gao"
  6. Out[2]: True 
  7.  
  8. In [3]: some_string.startswith("gao"
  9. Out[3]: False 
  10.  
  11. In [4]: some_string.endswith("good"
  12. Out[4]: True 
  13.  
  14. In [5]: some_string.endswith("gooD"
  15. Out[5]: False 
  16.  
  17. In [6]: some_string[:len("Gao")] == "Gao" 
  18. Out[6]: True 
  19.  
  20. In [7]: some_string[-len("good"):] == "good" 
  21. Out[7]: True 
  22. #切片操作可以创建并返回一个新的字符串对象,而不是在行内对字符串进行修改。 
  23. #脚本中切分一个字符串的频率,会对内存的性能有明显的影响。 
  24. #即使没有明显的性能影响,在使用startwith()和endswith() 
  25. #可以满足需要的情况下,应避免使用切片操作 
4,lstrip(),rstrip()和strip()
(帮助记忆:strip前边的l和r就是left和right)
 

 
  
  1. yuan@ThinkPad-SL510:~$ ipython -nobanner 
  2.  
  3. In [1]: xml_tag = "<some_tag>" 
  4.  
  5. In [2]: xml_tag.lstrip("<"
  6. Out[2]: 'some_tag>' 
  7.  
  8. In [3]: xml_tag.lstrip(">"
  9. Out[3]: '<some_tag>' 
  10.  
  11. In [4]: xml_tag.rstrip(">"
  12. Out[4]: '<some_tag' 
  13.  
  14. In [5]: xml_tag.rstrip("<"
  15. Out[5]: '<some_tag>' 
  16.  
  17. In [6]: xml_tag.strip("<").strip(">"
  18. Out[6]: 'some_tag' 
  19.  
  20. #因为strip等方法可以返回一个字符串,就可以在strip()调用之后直接调用另一个字符串操作。 

很明显strip方法会创建一个新字符串,这个和随后的replace方法一样,,而不是对原字符串进行行内修改。