Python之文本解析:字符串格式化的逆操作?
off999 2024-09-18 22:36 43 浏览 0 评论
引言
前面的文章中,提到了关于Python中字符串中的相关操作,更多地涉及到了字符串的格式化,有些地方也称为字符串插值操作,本质上,就是把多个字符串拼接在一起,以固定的格式呈现。
关于字符串的操作,其实还有另外一种场景,就是从固定格式的字符串中,解析、提取出我们想要的信息。实际工作中,更常用的是从用户行为日志中提取出相关信息,从而进行行为模式的识别与分析,继而辅助引导后续的运营动作。
关于从字符串中提取出所需要的信息,在老手看来,最容易想到的大概就是使用正则表达式了。
但是,正则表达式对新手不太友好,而且可读性太差,即便是熟练掌握了正则表达式的老手,隔了一段时间,回看自己写的正则表达式,也会有些吃力。
本文我们快速略过正则表达式的用法,然后重点介绍通过好用的第三方模块,来实现常规场景下的字符串内容解析、提取的工作。
用户行为日志
在系统的运营过程中,记录用户在系统中的各种访问行为,通过这些行为日志的提取、分析,学习出用户相关动作背后的特定模式,从而更好地实现产品的运营,留存用户、提高转化率等。
下面我们生成一些用户行为日志的测试数据,作为后续文本内容提取的输入,从而演示文本解析提取的运行效果。
from faker import Faker
import random
fk = Faker('zh_CN')
fp = open('./access_log.txt', 'a')
# 假设主要有以下几种行为:login, search, add2cart, buy
for i in range(100):
print(f"{fk.future_datetime()}#{fk.user_name()}@{fk.ipv4()}:action={random.choice(['login', 'search', 'add2cart', 'buy'])}", file=fp)
fp.close()
生成的日志内容,如下:
日志的格式为:
{访问时间}#{用户名}@{ip}:action={访问行为}
正则表达式
由于正则表达式比较复杂,暂时不需要用到正则表达式,只有一些特殊复杂的文本解析提取,才可能考虑用正则表达式,这里,简单举个例子,从文本中提取出所有的ip字段:
import re
pattern = r"\d+\.\d+\.\d+\.\d+"
with open('./access_log.txt', 'r') as fp:
text = fp.readline()
while text:
res = re.search(pattern, text)
if res:
print(res.group())
text = fp.readline()
输出结果:
关于正则表达式不再展开,需要用到的时候再行查阅吧。
当然,不通过正则表达式,也可以实现这个需求,只需要做字符串的分割就行了。
with open('./access_log.txt', 'r') as fp:
text = fp.readline()
while text:
print(text.split('@')[1].split(':')[0])
text = fp.readline()
parse模块
除了正则表达式这个核武器,以及字符串分割的土方法。其实,还有更加灵巧、轻便的解决方案,这就要用到第三方模块parse。
安装
三方模块,使用之前,需要先安装:
pip3 install parse
文档及源码地址
https://github.com/r1chardj0n3s/parse
日志解析
先来把前面的行为日志数据解析一下:
from parse import parse
pattern = '{}#{}@{}:action={}'
with open('./access_log.txt', 'r') as fp:
text = fp.readline()
while text:
res = parse(pattern, text)
if res:
dt, username, ip, action = res
print(dt)
print(username)
print(ip)
print(action)
text = fp.readline()
也可以通过关键字的形式,进行解析结果的提取:
from parse import parse
# 也可以通过关键字参数,返回的结果为字典形式的
pattern = '{dt}#{username}@{ip}:action={action}'
with open('./access_log.txt', 'r') as fp:
text = fp.readline()
while text:
res = parse(pattern, text)
if res:
dt = res['dt']
username = res['username']
ip = res['ip']
action = res['action']
print(dt)
print(username)
print(ip)
print(action)
text = fp.readline()
parse模块的其他功能:
前面解析日志中,我们只用到了parse模块中的parse()函数。
我们可以查看parse模块的源码,看下主要的功能:
parse模块的实现,依赖了正则表达式模块。
如同官网描述的一样,当我们通过:
from parse import *
只会导入4个函数:parse()、search()、findall()、with_pattern()。
关于这些函数的使用,感兴趣的可以查看源码自行研究。
其他模块
其实,关于文本数据的解析、提取,除了re、parse外,还有其他模块,分别用于更多的场景中的文本解析、提取。
比如HTML中的内容解析,可以使用lxml、beautifulsoup4,或者类似于jQuery的pyquery模块,也可以用于解析HTML文档。
这些模块在通过爬虫采集相关数据时,会更加便捷。
以后有机会,再进行相关的展开介绍。
相关推荐
- 键盘皮肤下载(键盘皮肤下载软件免费有音效)
-
1、vivo自带的输入法不能更换键盘皮肤;2、建议可以下载第三方输入法更换皮肤,比如:搜狗输入法等;3、下载第三方输入法之后需要在设置-更多设置-输入法中设置为第三方的输入法使用;4、然后在输入法界面...
- win11如何格式化硬盘(win11硬盘分区怎么改成gpt)
-
win11系统格式化电脑和硬盘的方法如下1、打开本地磁盘管理页面,右键点击需要格式化的磁盘,选择【格式化】。2、在弹出的窗口中,勾选【快速格式化】,点击【开始】。3、最后等待格式化完成即可。1.首先我...
- 还原ghost文件(ghost怎么还原)
-
ghost还原系统的前提是你的电脑里面装有ghost备份还原软件,并已经为计算机做过ghost系统备份,它使得电脑系统出现小故障,不能启动时,能够快速的恢复系统。其操作方法步骤如下:1、下载ghost...
- 安卓虚拟机运行windows(安卓虚拟机运行机制)
-
安卓无法直接安装Windows虚拟机,但是可以通过使用虚拟机应用或者远程桌面软件来连接已安装了Windows系统的电脑,达到在安卓系统中使用Windows的效果。其中,使用虚拟机应用需要先root安卓...
- img精简版pe下载(img格式pe下载)
-
答:img系统格式用u盘安装的办法。1.将IMG压缩文件(.img.gz)解压缩,得到.img文件,然后通过Win32DiskImager写入最终的硬盘。2.写好的磁盘直接启动就是安装好的...
-
- 华为手机按键怎么调出来(oppo手机按键怎么调出来)
-
华为手机功能键是指屏幕内三键导航,设置方法∶打开手机设置,点击系统和更新,点击系统导航方式,选择屏幕内三键导航,就在底部设置了导航键。华为手机功能键设置方法1.点击辅助功能进入华为手机的设置,点击辅助功能。2.点击系统导航方式点击系...
-
2025-12-12 13:51 off999
- 连接隔壁加密wifi密码(连接隔壁加密wifi密码有危险吗)
-
第一步:打开手机桌面上的万能钥匙后进入。第二步:点击右上角的一键查询万能钥匙搜索可用的无线网络。第三步:搜索完成后,可以看到无线网旁边有一个小钥匙图案,代表无线网可以连接。第四步:点击带钥匙图案的无线...
- win10系统为啥强制更新(win10系统强制更新怎么办)
-
当设置中系统更新处的wlan环境下自动更新开关打开时,手机满足连接wlan网络,手机屏幕熄灭和在充电状态的条件,条件满足将会进行智能更新下载。关闭时需要手动更新。任何手机都有新系统推送,推送新的功能,...
- 微软官网如何下载win10(微软官网怎么下载win10)
-
从微软官网下载win10具体有以下7步:1、输入微软的官网,进入。2、登录自己的账号。3、一直往下拉,可以看到“获取win10”。4、选择要下载的版本。5、选择下载到你自己制定的文件夹,点击...
- 兼容模式是什么意思(wifi5兼容模式是什么意思)
-
是指windows兼容模式,它是在windows中为程序提供了的兼容模式,是为了旧版本的软件能在新框架内运行而设置的。相对于软件,一种是指某个软件能稳定地工作在某操作系统之中,就说这个软件对这个操作系...
- c盘损坏进不了系统怎么恢复(c盘损坏能修复吗)
-
C盘坏了,一般都系统损坏,进入不了桌面,两种情况来硬件硬盘损坏,还是系统坏了?若是系统坏了,就需要重新格式化C盘,重新装载新的系统,一般就担心你的其它盘的数据是否能保存,所以先格式化C盘,其他盘先不格...
- vs2010使用教程下载(vs2010中文版下载)
-
VS2010的使用过程1)创建文件的方式为点击左上角文件->新建->文件,或者直接Ctrl+N,我们在使用这种大型开发工具的时候,需要选择项目工程的方式来进行使用,选择项目选项。2)然...
-
- qq邮箱的正确格式是什么
-
QQ邮箱格式有四种显示方式:①QQ号码@qq.com;②英文+数字@qq.com;③数字或英文@foxmail.com;④手机号@qq.com;QQ邮箱一共可以设置四个不同的QQ邮箱账号,但是都隶属于一个邮箱。默认邮箱一般为QQ号@qq.c...
-
2025-12-12 10:03 off999
- 软件商店下载安装到手机桌面上
-
在手机的应用商店里直接下载,就会自动安装,好了就在桌面。有以下几种可能的情况和解决办法:1.查找应用程序列表:在手机上按下主屏幕的应用程序图标或托盘中的应用程序列表,查找并点击已下载的应用,这样可以...
欢迎 你 发表评论:
- 一周热门
-
-
抖音上好看的小姐姐,Python给你都下载了
-
全网最简单易懂!495页Python漫画教程,高清PDF版免费下载
-
Python 3.14 的 UUIDv6/v7/v8 上新,别再用 uuid4 () 啦!
-
飞牛NAS部署TVGate Docker项目,实现内网一键转发、代理、jx
-
python入门到脱坑 输入与输出—str()函数
-
宝塔面板如何添加免费waf防火墙?(宝塔面板开启https)
-
Python三目运算基础与进阶_python三目运算符判断三个变量
-
(新版)Python 分布式爬虫与 JS 逆向进阶实战吾爱分享
-
失业程序员复习python笔记——条件与循环
-
使用 python-fire 快速构建 CLI_如何搭建python项目架构
-
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (77)
- python封装 (57)
- python写入txt (66)
- python读取文件夹下所有文件 (59)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)
