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

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

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

时间: 2024-11-04 10:18:26

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

python中的sort、sorted、reverse、reversed详解

python语言中的列表排序方法有三个:reverse反转/倒序排序.sort正序排序.sorted可以获取排序后的列表.在更高级列表排序中,后两中方法还可以加入条件参数进行排序. reverse()方法 将列表中元素反转排序,比如下面这样 1 2 3 4 >>> x = [1,5,2,3,4] >>> x.reverse() >>> x [4, 3, 2, 5, 1] reverse列表反转排序:是把原列表中的元素顺序从左至右的重新存放,而不会对列表

Python中Gradient Boosting Machine(GBM)调参方法详解

原文地址:Complete Guide to Parameter Tuning in Gradient Boosting (GBM) in Python by Aarshay Jain 原文翻译与校对:@酒酒Angie([email protected]) && 寒小阳([email protected]) 时间:2016年9月. 出处:http://blog.csdn.net/han_xiaoyang/article/details/52663170 1.前言 如果一直以来你只把GBM当

Python中re.match与re.search的使用方法详解

本文和大家分享的主要是python正则表达式中re.match函数与re.search方法的相关用法及异同点,希望通过本文的分享,能对大家有所帮助. re.match函数 re.match 尝试从字符串的起始位置匹配一个模式,如果不是起始位置匹配成功的话,match()就返回none. 函数语法: re.match(pattern, string, flags=0) 函数参数说明: 参数描述 pattern匹配的正则表达式 string要匹配的字符串. flags标志位,用于控制正则表达式的匹配

关于Python中的类普通继承与super函数继承

关于Python中的类普通继承与super函数继承 1.super只能用于新式类 2.多重继承super可以保公共父类仅被执行一次 一.首先看下普通继承的写法 二.再看看super继承的写法 参考链接:http://blog.csdn.net/lqhbupt/article/details/19631991

PE文件结构与函数导出表——详解与实例

PE文件结构与函数导出表--详解与实例 随着windows系统从Xp升级到Win7.Win8, 从32位升级到64位,PE文件结构在整体未变的情况下发生了一些小的变动,一方面是推荐的程序装载地址未采用,另一方面,导出函数序号不再是简单的升序,而是一定程度上的进行了乱序.本文首先对PE文件结构进行了详尽的解说,接着介绍了如何得出函数导出表,整个过程采用SysWoW64目录下的wininet.dll实例进行说明.在介绍过程中,明确指出了Win7.Win8等新系统相对Xp带来的区别. 文章链接:htt

第三百五十五节,Python分布式爬虫打造搜索引擎Scrapy精讲—scrapy信号详解

第三百五十五节,Python分布式爬虫打造搜索引擎Scrapy精讲-scrapy信号详解 信号一般使用信号分发器dispatcher.connect(),来设置信号,和信号触发函数,当捕获到信号时执行一个函数 dispatcher.connect()信号分发器,第一个参数信号触发函数,第二个参数是触发信号, signals.engine_started当Scrapy引擎启动爬取时发送该信号.该信号支持返回deferreds.signals.engine_stopped当Scrapy引擎停止时发送

[转]js中几种实用的跨域方法原理详解

转自:js中几种实用的跨域方法原理详解 - 无双 - 博客园 这里说的js跨域是指通过js在不同的域之间进行数据传输或通信,比如用ajax向一个不同的域请求数据,或者通过js获取页面中不同域的框架中(iframe)的数据.只要协议.域名.端口有任何一个不同,都被当作是不同的域. 下表给出了相对http://store.company.com/dir/page.html同源检测的结果: 要解决跨域的问题,我们可以使用以下几种方法: 一.通过jsonp跨域 在js中,我们直接用XMLHttpRequ

js中几种实用的跨域方法原理详解(转)

这里说的js跨域是指通过js在不同的域之间进行数据传输或通信,比如用ajax向一个不同的域请求数据,或者通过js获取页面中不同域的框架中(iframe)的数据.只要协议.域名.端口有任何一个不同,都被当作是不同的域. 下表给出了相对http://store.company.com/dir/page.html同源检测的结果: 要解决跨域的问题,我们可以使用以下几种方法: 一.通过jsonp跨域 在js中,我们直接用XMLHttpRequest请求不同域上的数据时,是不可以的.但是,在页面上引入不同

ios中创建可以拖动的view原理和实现详解

有时候我们会需要在界面上拖动view;uiview是继承于uiresponder的,所以可以响应触摸相关的事件. 重点是以下一组方法: - (void)touchesBegan:(NSSet *)touches withEvent:(UIEvent *)event - (void)touchesMoved:(NSSet *)touches withEvent:(UIEvent *)event - (void)touchesEnded:(NSSet *)touches withEvent:(UIE

ios中创建可以拖动的view原理和实现详解(含代码)

有时候我们会需要在界面上拖动view;uiview是继承于uiresponder的,所以可以响应触摸相关的事件. 重点是以下一组方法: - (void)touchesBegan:(NSSet *)touches withEvent:(UIEvent *)event - (void)touchesMoved:(NSSet *)touches withEvent:(UIEvent *)event - (void)touchesEnded:(NSSet *)touches withEvent:(UIE