⑴ python中split的用法問題
1、首先雙擊打開pycharm編輯工具之後,新建python文件split.py,如下圖所示。
⑵ 請問python3中的re.split與re.findall的區別
你的Python程序輸出結果是對的.
re.split是以re.compile中的正則表達式對字元串進行切分.
re.findall是以re.compile中的正則表達式對字元串進行匹配.
就拿你的例子來說吧,
re.split是以數字為邊界對字元串'one1two2three3four4'進行切分,得到['one','two','three','four','']五個字元串
re.findall是匹配字元串'one1two2three3four4'中的所有數字,得到['1','2','3','4']四個數字
⑶ python讀取一行文件內容後 怎麼拆分那行里的內容並加以利用
這個最好用正則表達式模塊進行正則表達式匹配來獲取所需要的內容。import re
⑷ Python 截取關鍵字後的字元串
使用json模塊就可以了
⑸ python中的strip和split結合起來怎麼用
python strip() 函數和 split() 函數的詳解及實例
一直以來都分不清楚strip和split的功能,實際上strip是刪除的意思;而split則是分割的意思。因此也表示了這兩個功能是完全不一樣的,strip可以刪除字元串的某些字元,而split則是根據規定的字元將字元串進行分割。下面就詳細說一下這兩個功能,
1 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刪除序列是只要邊(開頭或結尾)上的字元在刪除序列內,就刪除掉。
例如,
>>> a = ' 123'
>>> a
' 123'
>>> a.strip()
'123'
(2)這里的rm刪除序列是只要邊(開頭或結尾)上的字元在刪除序列內,就刪除掉。
例如,
>>> a = '123abc'
>>> a.strip('21')
'3abc'
>>> a.strip('12')
'3abc'
結果是一樣的。
2 python split()函數 介紹
說明:
Python中沒有字元類型的說法,只有字元串,這里所說的字元就是只包含一個字元的字元串!!!
這里這樣寫的原因只是為了方便理解,僅此而已。
(1)按某一個字元分割,如『.'
>>> str = ('www.google.com')
>>> print str
www.google.com
>>> str_split = str.split('.')
>>> print str_split
['www', 'google', 'com']
(2)按某一個字元分割,且分割n次。如按『.'分割1次
>>> str_split = str.split('.',1)
>>> print str_split
['www', 'google.com']
(3)split()函數後面還可以加正則表達式,例如:
>>> str_split = str.split('.')[0]
>>> print str_split
www
split分隔後是一個列表,[0]表示取其第一個元素;
>>> str_split = str.split('.')[::-1]
>>> print str_split
['com', 'google', 'www']
>>> str_split = str.split('.')[::]
>>> print str_split
['www', 'google', 'com']
按反序列排列,[::]安正序排列
>>> 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 ==> 數字
>>> 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]
>>> num2ip = lambda x: '.'.join([str(x/(256**i)%256) for i in range(3,-1,-1)])
>>> num2ip(3232235521)
'192.168.0.1'
最後,python怎樣將一個整數與IP地址相互轉換?
>>> 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 line.split 分隔符怎麼設置
代碼示例:
import re
re.split('; |, ',str)
例如:
>>> a='Beautiful, is; better*than\nugly'
>>> import re
>>> re.split('; |, |\*|\n',a)
['Beautiful', 'is', 'better', 'than', 'ugly']
⑺ python如何去掉split之後的第一個單詞
importre
print(re.sub(r'^w+s*','','inputa,bcd',count=1))
正則很適合做這種事情.
這個是刪掉了頂格起的第一個單詞及其右側緊挨著的所有白空格(如果有的話)
⑻ python: split的用法,在後面的括弧不同,輸出的也不一樣,大神能不能幫忙解釋一下下面的例子。
split的第一個參數是分隔符。
如果省略第一個參數,默認把所有的空格、製表符、回車符當作分隔符,並過濾掉空串。這個也是你第一種寫法的效果。
line.split(『\t''\n')
'\t'和'\n'是兩個字元串,會自動進行拼接,形成'\t\n'作為分隔符。而在你輸入的字元串中,不包含這樣的字串,所以就分割的結果就是原串。
split(『\t')
以'\t'作為分隔符,分割的結果就是第三種寫法。
split不支持同時使用多種字元做分隔符,如果想實現這樣的效果,可以用re,例如:
>>> a
'wowofbfwjowoefbwfoweojbwoefja'
>>> import re
>>> re.split('[ab]', a)
['wowof', 'fwjowoef', 'wfoweoj', 'woefj', '']
⑼ python split 函數 入門問題
$ python
Python 2.4.3 (#1, Sep 3 2009, 15:37:12)
[GCC 4.1.2 20080704 (Red Hat 4.1.2-46)] on linux2
Type "help", "right", "credits" or "license" for more information.
>>> import re
>>> date = '1988年5月23日周一'
>>> print(re.findall("[0-9]+",date))
['1988', '5', '23']