百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

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.首先我...

手机u盘怎么打开(手机u盘怎么打开怎么使用)
  • 手机u盘怎么打开(手机u盘怎么打开怎么使用)
  • 手机u盘怎么打开(手机u盘怎么打开怎么使用)
  • 手机u盘怎么打开(手机u盘怎么打开怎么使用)
  • 手机u盘怎么打开(手机u盘怎么打开怎么使用)
还原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手机按键怎么调出来)
华为手机按键怎么调出来(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号码@qq.com;②英文+数字@qq.com;③数字或英文@foxmail.com;④手机号@qq.com;QQ邮箱一共可以设置四个不同的QQ邮箱账号,但是都隶属于一个邮箱。默认邮箱一般为QQ号@qq.c...

2025-12-12 10:03 off999

软件商店下载安装到手机桌面上

在手机的应用商店里直接下载,就会自动安装,好了就在桌面。有以下几种可能的情况和解决办法:1.查找应用程序列表:在手机上按下主屏幕的应用程序图标或托盘中的应用程序列表,查找并点击已下载的应用,这样可以...

取消回复欢迎 发表评论: