码迷,mamicode.com
首页 > 编程语言 > 详细

python 中join()函数strip() 函数和 split() 函数的详解及实例

时间:2017-07-14 00:43:26      阅读:294      评论:0      收藏:0      [点我收藏+]

标签:strong   阅读   comment   字典   ace   height   没有   for   lin   

1、join()函数

Python中有join()和os.path.join()两个函数,具体作用如下:

join():                连接字符串数组。将字符串、元组、列表中的元素以指定的字符(分隔符)连接生成一个新的字符串

语法:  ‘sep‘.join(seq)

参数说明
sep:分隔符。可以为空
seq:要连接的元素序列、字符串、元组、字典
上面的语法即:以sep作为分隔符,将seq所有的元素合并成一个新的字符串

返回值:返回一个以分隔符sep连接各个元素后生成的字符串

 


 

os.path.join():  将多个路径组合后返回

语法:  os.path.join(path1[,path2[,......]])

返回值:将多个路径组合后返回

注:第一个绝对路径之前的参数将被忽略

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
#对序列进行操作(分别使用‘ ‘与‘:‘作为分隔符)
  
>>> seq1 = [‘hello‘,‘good‘,‘boy‘,‘doiido‘]
>>> print ‘ ‘.join(seq1)
hello good boy doiido
>>> print ‘:‘.join(seq1)
hello:good:boy:doiido
  
  
#对字符串进行操作
  
>>> seq2 = "hello good boy doiido"
>>> print ‘:‘.join(seq2)
h:e:l:l:o: :g:o:o:d: :b:o:y: :d:o:i:i:d:o
  
  
#对元组进行操作
  
>>> seq3 = (‘hello‘,‘good‘,‘boy‘,‘doiido‘)
>>> print ‘:‘.join(seq3)
hello:good:boy:doiido
  
  
#对字典进行操作
  
>>> seq4 = {‘hello‘:1,‘good‘:2,‘boy‘:3,‘doiido‘:4}
>>> print ‘:‘.join(seq4)
boy:good:doiido:hello
  
  
#合并目录
  
>>> import os
>>> os.path.join(‘/hello/‘,‘good/boy/‘,‘doiido‘)
‘/hello/good/boy/doiido‘

 

2,Python strip()函数 介绍

函数原型

声明:s为字符串,rm为要删除的字符序列

s.strip(rm)       删除s字符串中开头、结尾处,位于 rm删除序列的字符

s.lstrip(rm)      删除s字符串中开头处,位于 rm删除序列的字符

s.rstrip(rm)     删除s字符串中结尾处,位于 rm删除序列的字符

注意:

(1)当rm为空时,默认删除空白符(包括‘\n‘, ‘\r‘, ‘\t‘,  ‘ ‘)

(2)这里的rm删除序列是只要边(开头或结尾)上的字符在删除序列内,就删除掉。

例如,

1
2
3
4
5
>>> a = ‘  123‘
>>> a
‘  123‘
>>> a.strip()
‘123‘

(2)这里的rm删除序列是只要边(开头或结尾)上的字符在删除序列内,就删除掉。

例如,

1
2
3
4
5
>>> a = ‘123abc‘
>>> a.strip(‘21‘)
‘3abc‘
>>> a.strip(‘12‘)
‘3abc‘

结果是一样的。

3, python split()函数 介绍

说明:

Python中没有字符类型的说法,只有字符串,这里所说的字符就是只包含一个字符的字符串!!!

这里这样写的原因只是为了方便理解,仅此而已。

(1)按某一个字符分割,如‘.‘

1
2
3
4
5
6
>>> str = (‘www.google.com‘)
>>> print str
www.google.com
>>> str_split = str.split(‘.‘)
>>> print str_split
[‘www‘, ‘google‘, ‘com‘]

(2)按某一个字符分割,且分割n次。如按‘.‘分割1次

1
2
3
>>> str_split = str.split(‘.‘,1)
>>> print str_split
[‘www‘, ‘google.com‘]

(3)split()函数后面还可以加正则表达式,例如:

1
2
3
>>> str_split = str.split(‘.‘)[0]
>>> print str_split
www

split分隔后是一个列表,[0]表示取其第一个元素;

1
2
3
4
5
6
>>> str_split = str.split(‘.‘)[::-1]
>>> print str_split
[‘com‘, ‘google‘, ‘www‘]
>>> str_split = str.split(‘.‘)[::]
>>> print str_split
[‘www‘, ‘google‘, ‘com‘]

按反序列排列,[::]安正序排列

1
2
3
4
5
6
7
8
9
>>> str = str + ‘.com.cn‘
>>> str
‘www.google.com.com.cn‘
>>> str_split = str.split(‘.‘)[::-1]
>>> print str_split
[‘cn‘, ‘com‘, ‘com‘, ‘google‘, ‘www‘]
>>> str_split = str.split(‘.‘)[:-1]
>>> print str_split
[‘www‘, ‘google‘, ‘com‘, ‘com‘]

从首个元素开始到次末尾,最后一个元素删除掉。

split()函数典型应用之一,ip数字互换:

# ip ==> 数字

1
2
3
>>> ip2num = lambda x:sum([256**j*int(i) for j,i in enumerate(x.split(‘.‘)[::-1])])
>>> ip2num(‘192.168.0.1‘)
3232235521

# 数字 ==> ip # 数字范围[0, 255^4]

1
2
3
>>> num2ip = lambda x: ‘.‘.join([str(x/(256**i)%256) for i in range(3,-1,-1)])
>>> num2ip(3232235521)
‘192.168.0.1‘

最后,python怎样将一个整数与IP地址相互转换?

1
2
3
4
5
6
7
>>> import socket
>>> import struct
>>> int_ip = 123456789
>>> socket.inet_ntoa(struct.pack(‘I‘,socket.htonl(int_ip)))#整数转换为ip地址
7.91.205.21
>>> str(socket.ntohl(struct.unpack(“I”,socket.inet_aton(“255.255.255.255″))[0]))#ip地址转换为整数
4294967295

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

 

python 中join()函数strip() 函数和 split() 函数的详解及实例

标签:strong   阅读   comment   字典   ace   height   没有   for   lin   

原文地址:http://www.cnblogs.com/guoy/p/7163705.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!