Python 結(jié)構(gòu)化字符串中提取數(shù)據(jù)詳情
前言
在許多自動化任務(wù)中,我們都需要從已知格式結(jié)構(gòu)化的輸入文本中提取相關(guān)信息。例如,我們可能需要在一段電影評論數(shù)據(jù)中提取觀影時間、電影名、評分等信息,以便存儲后進行進一步分析。在本節(jié)中,我們將以提取電影評論數(shù)據(jù)信息為例講解如何從結(jié)構(gòu)化字符串中提取數(shù)據(jù)。
從結(jié)構(gòu)化字符串中提取數(shù)據(jù)
假設(shè)我們具有以下結(jié)構(gòu)的電影評分數(shù)據(jù),我們需要解析存儲觀影時間、電影名、評分等信息:
[<Timestamp>] -?MOVIE ID: <movie id>?- MOVIE NAME: <movie name>?- SCORE: <score of the movie>
例如,一條可能的電影評分記錄如下所示:
[2022-08-01T11:58:41.504054] - MOVIE ID: 00015?- MOVIE NAME: Inception?- SCORE: 8.5
其中,我們使用標準格式表示時間和日期,這在計算機中廣泛應(yīng)用。
字符串解析
首先,導(dǎo)入所需庫,并給出所需解析的用戶對電影的評分記錄:
>>> import delorean >>> from decimal import Decimal >>> text = '[2022-08-01T11:58:41.504054] - MOVIE ID: 00015 - MOVIE NAME: Inception - SCORE: 8.5'
將評分記錄使用 split()
方法拆分為多個部分,我們使用 “-
” 作為分隔符拆分每個元素,將評分記錄拆分為 4
部分——時間戳、電影 ID
、電影名和電影評分,便于之后將它們解析為正確的類型:
>>> divided_text = text.split(' - ') >>> divided_text ['[2022-08-01T11:58:41.504054]', 'MOVIE ID: 00015', 'MOVIE NAME: Inception', 'SCORE: 8.5'] >>> timestamp, movie_id, movie_name, score = divided_text
將時間戳解析為 datetime
對象。由于在評分記錄中時間戳包含在方括號中,為了正確解析時間戳,需要去掉括號,然后使用 delorean
模塊將其解析為日期時間對象:
>>> timestamp = delorean.parse(timestamp.strip('[]')) >>> timestamp Delorean(datetime=datetime.datetime(2022, 1, 8, 11, 58, 41, 504054), timezone='UTC')
將 movie_id
解析為整數(shù)。為了解析電影 ID
,需要使用冒號作為分隔符拆分 movie_id
,然后,將最后一個元素解析為整數(shù):
>>> movie_id = int(movie_id.split(':')[-1]) >>> movie_id 15
將評分解析為 Decimal
類型。為了解析電影評分,我們同樣使用冒號作為分隔符拆分 score
,并將其解析為十進制字符對象 Decimal
(這是由于此值解析為浮點類型會改變精度):
>>> score = Decimal(score.split(':')[-1]) >>> score Decimal('8.5')
為了便于解析和聚合,我們可以將所解析的數(shù)據(jù)組合在一起成為一個對象。例如,我們可以通過在 Python
代碼中定義一個類,來方便的解析和聚合結(jié)構(gòu)化字符串中的數(shù)據(jù):
class Movie(object): ????def __init__(self, timestamp, movie_id, movie_name, score): ????????self.timestamp = timestamp ????????self.movie_id = movie_id ????????self.movie_name = movie_name ????????self.score = score ????def __repr__(self): ????????return '<Movie ({}, {}, {})>'.format(self.timestamp, self.movie_id, self.movie_name, self.score) ????@classmethod ????def parse(cls, text): ????????''' ????????Parse from a text with the format ????????[<Timestamp>] - MOVIE ID: <movie id> - MOVIE NAME: <movie name> - SCORE: <score of the movie> ????????to a Movie object ????????''' ????????divided_text = text.split(' - ') ????????timestamp, movie_id, movie_name, score = divided_text ????????timestamp = delorean.parse(timestamp.strip('[]')) ????????movie_id = int(movie_id.split(':')[-1]) ????????movie_name = movie_name.split(':')[-1] ????????score = Decimal(score.split(':')[-1]) ????????return cls(timestamp=timestamp, movie_id=movie_id, movie_name=movie_name, score=score)
定義 Movie
類完成后,我們可以使用以下方式方便的對評分記錄進行解析:
>>> Movie.parse(text) <Movie (Delorean(datetime=datetime.datetime(2022, 1, 8, 11, 58, 41, 504054), timezone='UTC'), 15, ?Inception)>
到此這篇關(guān)于Python 結(jié)構(gòu)化字符串中提取數(shù)據(jù)詳情的文章就介紹到這了,更多相關(guān)Python 提取數(shù)據(jù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python簡單調(diào)用MySQL存儲過程并獲得返回值的方法
這篇文章主要介紹了Python調(diào)用MySQL存儲過程并獲得返回值的方法,涉及Python操作MySQL存儲過程的使用技巧,具有一定參考借鑒價值,需要的朋友可以參考下2015-07-07Python+OpenCV圖像處理—— 色彩空間轉(zhuǎn)換
這篇文章主要介紹了Python+OpenCV如何對圖片進行色彩空間轉(zhuǎn)換,幫助大家更好的利用python處理圖片,感興趣的朋友可以了解下下2020-10-10python opencv實現(xiàn)圖片旋轉(zhuǎn)矩形分割
這篇文章主要為大家詳細介紹了python opencv實現(xiàn)圖片旋轉(zhuǎn)矩形分割,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-07-07