1. 程式人生 > >Python基本知識 os.path.join與split() 函數

Python基本知識 os.path.join與split() 函數

.net 元組 spl nbsp 路徑 元素 .html too 技術分享

Python中有join和os.path.join()兩個函數,具體作用如下:

join:連接字符串數組。將字符串、元組、列表中的元素以指定的字符(分隔符)連接生成一個新的字符串
os.path.join(): 將多個路徑組合後返回

一、函數說明

1.join()函數

語法:‘sep’.join(seq)

參數說明:

sep:分隔符。可以為空

seq:要連接的元素序列、字符串、元組、字典等

上面的語法即:以sep作為分隔符,將seq所有的元素合並成一個新的字符串

返回值:返回一個以分隔符sep連接各個元素後生成的字符串

2、os.path.join()函數

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

返回值:將多個路徑組合後返回

註:第一個絕對路徑之前的參數將被忽略

實例:

#對序列進行操作(分別使用‘ ‘與‘:‘作為分隔符) >>> 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‘

在OSChina上也有一個九九乘法表的代碼,如下(原文鏈接:http://www.oschina.net/code/snippet_53549_2238)

print ‘\n‘.join([‘ ‘.join([‘%s*%s=%-2s‘ % (y,x,x*y) for y in range(1,x+1)])for x in range(1,10)])

短短一句話,就完美打印出九九乘法表。

對此段代碼的賞析,百度博客有篇文章介紹的很清楚,在此不多說。

原文如下:(鏈接:http://hi.baidu.com/fc_lamp/blog/item/fb7d410bf7314c0295ca6b8c.html)

淺析一句python代碼成生九九乘法表 2011-11-24 11:58

最近在oschina上看到段九九乘法表 的代碼,如下:

print‘\n‘.join([‘ ‘.join([‘%s*%s=%-2s‘%(y,x,x*y) fory in range(1,x+1)]) forx in range(1,10)])

(來至於:http://www.oschina.net/code/snippet_53549_2238)

我稍微調整了一下:

#coding:utf-8
print(‘\n‘.join([‘ ‘.join(‘%sx%s=%-2s‘%(x,y,x*y) for x in xrange(1,y+1)) for y in xrange(1,10)]))

恩,其實兩代碼都參不多,那麽我們就來解析一下,這段代碼:

首先:要使用的主要知識點:

1 列表解析知識(以及元組知識)

2 range,xrange,join函數的使用

3 字符串格式化輸出

技術分享圖片

技術分享圖片

Python中有split()和os.path.split()兩個函數:

split():拆分字符串。通過指定分隔符對字符串進行切片,並返回分割後的字符串列表。

os.path.split():將文件名和路徑分割開。

1、split()函數
語法:str.split(str=" ",num=string.count(str))[n]

參數說明:
str: 表示為分隔符,默認為空格,但是不能為空串。若字符串中沒有分隔符,則把整個字符串作為列表的一個元素。
num:表示分割次數。如果存在參數num,則僅分隔成 num+1 個子字符串。
[n]: 表示選取第n個分片(從0計數)

默認情況下,使用空格作為分隔符,則分隔後,空串會自動忽略,如:

>>> s=‘love    python‘

>>> s.split()
[‘love‘, ‘python‘]

但若顯式指定空格為分隔符,則不會自動忽略空串,如:

>>> s.split(‘ ‘)
[‘love‘, ‘‘, ‘‘, ‘‘, ‘python‘]

默認的分隔符除了空格,還有 ‘\n\t\r‘,分隔後,空串會自動忽略,如下:

技術分享圖片
>>> s=‘love \n\t\r  \t\r\n python  \n\t\r‘
>>> s.split()
[‘love‘, ‘python‘]

 

>>> s=‘www.pku.edu.cn‘
技術分享圖片

>>> s.split() #默認空格作為分隔符,但字符串中沒有分隔符,因此,把整個字符串作為列表的一個元素
[‘www.pku.edu.cn‘]

>>> s.split(‘.‘) #以‘.‘作為分隔符,沒有指定分隔次數,則有多少 ‘.‘ 就分隔多少次
[‘www‘, ‘pku‘, ‘edu‘, ‘cn‘]

>>> s.split(‘.‘,0) #分隔0次
[‘www.pku.edu.cn‘]

>>> s.split(‘.‘,1) #分隔1次
[‘www‘, ‘pku.edu.cn‘]

>>> s.split(‘.‘,2)#分隔2次
[‘www‘, ‘pku‘, ‘edu.cn‘]

>>> s.split(‘.‘,2)[1]#分隔2次,取索引為1的項
‘pku‘

>>> s.split(‘.‘,-1) #盡可能多的分隔,與不加num參數相同
[‘www‘, ‘pku‘, ‘edu‘, ‘cn‘]

>>> s1,s2=s.split(‘.‘,1)#分隔1次,並把分隔後的2個字符串存放在s1和s2中
>>> s1
‘www

‘love\nhello\npython‘
>>> s.split(‘\n‘)#以‘\n‘作為分隔符,分隔次數盡可能的多
[‘love‘, ‘hello‘, ‘python‘]
>>> print s
love
hello
python

練習一下下面的例子:

技術分享圖片
>>> s=‘hello python<[www.python.com]>hello python‘
>>> s.split(‘[‘)[1].split(‘]‘)[0]
‘www.python.com‘
>>> s.split(‘[‘)[1].split(‘]‘)[0].split(‘.‘)
[‘www‘, ‘python‘, ‘com‘]
技術分享圖片

2、os.path.split()函數
語法:os.path.split(‘PATH‘)

參數說明:

  1. PATH指一個文件的全路徑作為參數:
  2. 如果給出的是一個目錄和文件名,則輸出路徑和文件名
  3. 如果給出的是一個目錄名,則輸出路徑和為空文件名
實際上,該函數的分割並不智能,它僅僅是以 "PATH" 中最後一個 ‘/‘ 作為分隔符,分隔後,將索引為0的視為目錄(路徑),將索引為1的視為文件名,如: 技術分享圖片
>>> import os
>>> os.path.split(‘C:/soft/python/test.py‘)
(‘C:/soft/python‘, ‘test.py‘)
>>> os.path.split(‘C:/soft/python/test‘)
(‘C:/soft/python‘, ‘test‘)
>>> os.path.split(‘C:/soft/python/‘)
(‘C:/soft/python‘, ‘‘)

Python基本知識 os.path.join與split() 函數