网站首页 > 教程分享 正文
我们在文本处理的过程中, 经常需要在特定文本中, 找到指定文本的位置, 或者确定某个字符串是否在特定文本中出现。
这样的操作, 在perl中一般直接可以使用substr方法或者正则来处理, Perl已经帮我包装好了。
今天我们自己来根据朴素字符串匹配方法来实现字符串查找的功能。
朴素字符串匹配算法就是通过一个循环依次增加偏移量,来确定整个字符串的偏移量,从而确定字符串的具体位置。
具体实现如下:
先定义字符串, 然后将字符串切割成字符数组:
my $long_str = 'hello,easyperl,hello world';
my $str = 'easyperl';
my @long_str_chars = split '', $long_str;
my @str_chars = split '', $str;
这边我们设置一个标签量, 用来确定是否匹配
my $flag = -1;
依次增加偏移量:
OUTER:
for my $index(0..@long_str_chars - @str_chars){
对于每次偏移, 依次比较所有对应字符
如果任何一个不对应, 则跳出该循环, 增加偏移量继续:
for my $index_in(0..@str_chars - 1){
next OUTER if $long_str_chars[$index + $index_in] ne $str_chars[$index_in];
}
如果都匹配, 则返回结果, 改变标签值, 提前结束循环
print "result: $index\n";
$flag = 1;
last OUTER;
}
print "result: not found\n" if $flag == -1;
猜你喜欢
- 2024-10-27 前端教程:JavaScript对象(js对象的操作方法)
- 2024-10-27 在UnRaid系统的DASHBOARD中显示CPU和主板的温度
- 2024-10-27 为什么我十分喜欢C,却很不喜欢C++
- 2024-10-27 想赚高薪?看了这些编程语言的入门方法,学习和玩一样轻松
- 2024-10-27 《Python核心编程》(第2版)第2章 快速入门
- 2024-10-27 程序员5种编程入门方法(程序员5种编程入门方法图解)
- 2024-10-27 你不可能还不会python变量的类型吧?
- 2024-10-27 Perl模式匹配大型连载3——s替换操作
- 2024-10-27 Cobalt Strike 4.8 用户指南-第五节-获取初始访问
- 2024-10-27 「实战」助力数据库开发之接口篇 - Perl 连接 Greenplum
你 发表评论:
欢迎- 最近发表
-
- 有了这份900多页的Android面试指南,你离大厂Offer还远吗?
- K2 Blackpearl 流程平台总体功能介绍:常规流程功能
- 零基础安卓开发起步(一)(安卓开发入门视频)
- 教程:让你的安卓像Windows一样实现程序窗口化运行
- Android事件总线还能怎么玩?(事件总线有什么好处)
- Android 面试被问“谈谈架构”,到底要怎样回答才好?
- Android开发工具Parcel和Serialize
- Android 中Notification的运用(notification widget安卓)
- Android退出所有Activity最优雅的方式
- MT管理器-简单实战-去除启动页(mt管理器怎么去除软件弹窗)
- 标签列表
-
- css导航条 (66)
- sqlinsert (63)
- js提交表单 (60)
- param (62)
- parentelement (65)
- jquery分享 (62)
- check约束 (64)
- curl_init (68)
- sql if语句 (69)
- import (66)
- chmod文件夹 (71)
- clearinterval (71)
- pythonrange (62)
- 数组长度 (61)
- javafx (59)
- 全局消息钩子 (64)
- sort排序 (62)
- jdbc (69)
- php网页源码 (59)
- assert h (69)
- httpclientjar (60)
- postgresql conf (59)
- winform开发 (59)
- mysql数字类型 (71)
- drawimage (61)
本文暂时没有评论,来添加一个吧(●'◡'●)