Python中的join()函數split()函數

函數:string.join()python

Python中有join()和os.path.join()兩個函數,具體做用以下:
    join():    鏈接字符串數組。將字符串、元組、列表中的元素以指定的字符(分隔符)鏈接生成一個新的字符串
    os.path.join():  將多個路徑組合後返回linux

1、函數說明
一、join()函數
windows

語法:  'sep'.join(seq)數組

參數說明
sep:分隔符。能夠爲空
seq:要鏈接的元素序列、字符串、元組、字典
上面的語法即:以sep做爲分隔符,將seq全部的元素合併成一個新的字符串函數

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

二、os.path.join()函數code

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

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

注:第一個絕對路徑以前的參數將被忽略element

注:容器對象內的元素須爲字符類型

#對序列進行操做(分別使用' '與':'做爲分隔符)
>>> 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
 
#對字典進行操做:   dict是以Key值做鏈接, #dict 的無序性,使元素隨機鏈接。set 同理
>>> seq4 = {'hello':1,'good':2,'boy':3,'doiido':4}
>>> print ':'.join(seq4)
boy:good:doiido:hello
 
#合併目錄
>>> import os
>>> os.path.join('hello','goodboy','doiido')
'hello\goodboy\doiido'   #windows platform auto add \ between each string
'hello/goodboy/doiido'      #linux platform auto add / between each string

----------------------------------------------------------------------------------------------

函數:split()

Python中有split()和os.path.split()兩個函數,具體做用以下:
split():拆分字符串。經過指定分隔符對字符串進行切片,並返回分割後的字符串列表(list)
os.path.split():按照路徑將文件名和路徑分割開

1、函數說明
一、split()函數

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

參數說明:
str:   表示爲分隔符,默認爲空格,可是不能爲空('')。若字符串中沒有分隔符,則把整個字符串做爲列表的一個元素
num:表示分割次數。若是存在參數num,則僅分隔成 num+1 個子字符串,而且每個子字符串能夠賦給新的變量
[n]:   表示選取第n個分片

注意:當使用空格做爲分隔符時,對於中間爲空的項會自動忽略

二、os.path.split()函數
語法:os.path.split('PATH')

參數說明:

    1. PATH指一個文件的全路徑做爲參數:
    2. 若是給出的是一個目錄和文件名,則輸出路徑和文件名
    3. 若是給出的是一個目錄名,則輸出路徑和爲空文件名

 

>>> u = "www.doiido.com.cn"
  
#使用默認分隔符
>>> print u.split()
['www.doiido.com.cn']
  
#以"."爲分隔符
>>> print u.split('.')
['www', 'doiido', 'com', 'cn']
  
#分割0次
>>> print u.split('.',0)
['www.doiido.com.cn']
  
#分割一次
>>> print u.split('.',1)
['www', 'doiido.com.cn']
  
#分割兩次
>>> print u.split('.',2)
['www', 'doiido', 'com.cn']
  
#分割兩次,並取序列爲1的項
>>> print u.split('.',2)[1]
doiido
  
#分割最屢次(實際與不加num參數相同)
>>> print u.split('.',-1)
['www', 'doiido', 'com', 'cn']
  
#分割兩次,並把分割後的三個部分保存到三個文件
>>> u1,u2,u3 = u.split('.',2)
>>> print u1
www
>>> print u2
doiido
>>> print u3
com.cn
----------------------------------------------------------------------------------------
去掉換行符
>>> c = '''say
hello
baby'''
  
>>> print c
say
hello
baby
  
>>> print c.split('\n')
['say', 'hello', 'baby']
 
分離文件名和路徑
>>> import os
>>> print os.path.split('/dodo/soft/python/')
('/dodo/soft/python', '')
>>> print os.path.split('/dodo/soft/python')
('/dodo/soft', 'python')
 
一個超級好的例子
>>> str="hello boy<[www.doiido.com]>byebye"
  
>>> print str.split("[")[1].split("]")[0]
www.doiido.com
  
>>> print str.split("[")[1].split("]")[0].split(".")
['www', 'doiido', 'com']
 
 
 
 
 
import osdef currentpath(file):    try:        filepath = os.path.abspath(            os.path.join(                os.path.join(os.path.dirname(file), os.pardir), os.pardir, 'elements/' + 'IOS' + '_elements'))        return filepath    except Exception,msg:        print msgprint __file__  #allen.pys1 = os.path.abspath(__file__) print s1         # C:\pythonn\allen.pys2 = os.path.dirname(s1)print s2         # C:\pythonnprint os.pardir   # ..print currentpath(__file__)  # C:\elements\IOS_elementsprint os.path.join('hello','good','boy')  # hello\good\boy
相關文章
相關標籤/搜索