- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我有一个包含字符串的文本文件,对于每个字符串,我需要划分并捕获它的每个部分。
字符串是这样的:
Joao.Martins.G2R71.Pedro.Feliz.sno
Being: NAME 1st player (only first or first+surname) G = game (can be 2 or 02 or other number less than 99) ; R = 结果(在本例中主队 wis 7x1)和 NAME 2nd player ... 最后 3 个字符是游戏类型(本例斯诺克)
但字符串也可以是:
Joao Martins |2x71| Pedro Feliz.poo
我不是 Regex 专家(遗憾的是)并且已经在这里搜索了很多问题而没有找到解决方案,或者就此而言甚至只是通过阅读其他问题的答案来获得帮助(主要是因为我似乎从来没有理解过这一点)
我已经有了这个:
preg_match("/\[(|^|]+)\]/",$string,$result);
echo $result[1] . "<br />";
但这只给了我 | 之间的所有东西|部分甚至不分开它们并忽略其他一切
你们能帮我解决这两种情况吗?我像往常一样完全迷失在这里!
提前致谢!
最佳答案
展开
方式:你不必使用复杂的正则表达式,你可以使用简单的 explode
.
$parts = explode( '.', $string);
零件现在是 2 个零件还是 6 个零件,所以您可以:
if( count( $parts) == 6)){
list( $fistName1, $surName1, $string, $fistName2, $surName2, $gameType) = $parts;
} elseif( count( $parts) == 2) {
$gameType = $parts[1];
list( $fistName1, $surName1, $string, $fistName2, $surName2) = explode( $parts[0]);
} else {
echo "Cannot parse";
}
现在正在解析 $gameType
:)
if( preg_match( '~^\|(\d+)x(\d+)\|$~', $gameType, $parts)){
$first = $parts[1];
$second = $parts[2];
} elseif( preg_match( '~^G(\d+)R(\d+)$~', $gameType, $parts)){
$first = $parts[1];
$second = $parts[2];
} else {
echo "Cannot parse!";
}
preg_match
方式:第二个正则表达式是有意不同的,所以你可以看到如何编写正则表达式来“吃掉”整个名字,不管它有 2,3 还是 5 个部分,你会习惯 *?
(贪婪 killer )。
$match = array();
if( preg_match( '~^(\w+)\.(\w+)\.G(\d+)R(\d+)\.(\w+)\.(\w+)\.(\w+)$~', $text, $match)){
// First way
} elseif (preg_match( '~^([^\|]+)\|(\d+)x(\d+)\|(.*?)\.(\w+)$~', $text, $match)){
// Second way
} else {
// Failed to parse
}
如果玩家可能有超过 2 个名字(比如 Armin Van Buuren
),你应该像这样使用正则表达式:
~^([\w.]+)\.G(\d+)R(\d+)\.([\w.]+)\.(\w+)$~
这将匹配 Albert.Einstein
、Armin.Van.Buuren
中的名称(regexp 依赖于该名称不包含 \d
(十进制数)所以像 Gerold The 3rd
这样的名字将不匹配)。
你应该只使用:~^([\w\d.]+)\.G(\d+)R(\d+)\.([\w\d.]+)\.(\w+)$~
也匹配 Gerold The 3rd
和任何其他名称 (\.G(\d+)R(\d+)\.
非常严格,你必须编出非常疯狂的名字,如 G3R01
(如“3l1t33 kid Gerold”)才能解析错误。
哦还有一件事,别忘了$name = strtr( $name, '.', ' ')
:)
~~
- regexp delimiter ;开始结束结束正则表达式; ~regexp~
,它几乎可以是任何/regexp/
, (regexp)
^
和 $
- meta characters ;^
字符串/行开始,$
字符串/行结束\w
是 escape sequence对于任何单词字符,与 [a-zA-Z]
([\w.]+)
- 捕获 subpatern/match group what 包含 [a-zA-Z.]
至少一次。 +
被称为 quantifier +?
- ?
(在其他量词之后)被称为贪心 killer ,它的意思是尽可能少拿,通常(\w+)a
将匹配(在字符串 ababa
上)abab
,(\w+?)a
将匹配 ab
和 (\w*?)a
将匹配空字符串 :)关于php - preg_match 捕获特殊字符后的字符串部分,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9217983/
我以一种特殊的方式收到以下错误。 The point at which the driver is attempting to click on the element was not scrolle
我有一些包含如下方法的编译库: public boolean foo(String userID) { Class ntSystemClass = Thread.currentThread()
假设我有下表 name | genre --------------------- book 1 | scifi book 2 | horror book 3
我正在用代码进行语言翻译。 self.title.text = [NSString stringWithFormat:NSLocalizedString(@"Q%ld", nil), (long)qu
我想这样做,但到目前为止,我所拥有的只是: print("Will you go out with me?") 我希望代码能够正常工作,以便人们可以回答“是/否”,如果回答是"is",则将返回一条消息
这个问题在这里已经有了答案: 关闭 11 年前。 Possible Duplicate: How can I decode html characters in c#? 我有来自 HTML 的字符,
我想在 JavaScript 中对以下形式的字符串执行 ucwords(),它应该返回 Test1_Test2_Test3。 我已经在 SO 上找到了一个 ucwords 函数,但它只需要空格作为新词
“任何长度的正数表示为数字字符数组,因此介于‘0’和‘9’之间。我们知道最重要的密码位于数组索引 0 的位置。 例子: - 号码是 10282 - 数组将是数字 = [1,0,2,8,2] 考虑到这一
我目前正在开发一个显示特殊 unicode 字符(例如 ꁴ)的应用 现在我遇到了在旧设备上无法显示这些符号的问题。我如何知道它是否适用于当前设备? 我是否必须为每个 SDK 版本创建一个虚拟 Andr
在 HTML、XML 和部分 DTD 中,有两种特殊的标记结构: 以感叹号开头的标签结束,例如 和 以问号开头的标签 ,例如 和 我的问题是,这些构造类型中的每一种是否都有不同的名称,或者我是否必
我目前正在用 python 构建一个 shell。shell 可以执行 python 文件,但我还需要添加使用 PIPE 的选项(例如“|”表示第一个命令的输出将是第二个命令的输入)。 为了做到这一点
我的 MVC 项目中的路由无法正常工作... 我希望我所有的 View 都在 Views > Shared 文件夹中,如下所示: Error.cshtml (default) Index.cshtml
我有一个函数: public static ImageIcon GetIconImageFromResource(String path){ URL url = ARMMain.class.g
好的,所以我想在我的 html 页面中包含下面的字符。看起来很简单,只是我找不到它们的 HTML 编码。 注意:我想在没有大小元素的情况下执行此操作,纯文本就可以了 ^_^。 干杯。 最佳答案 你可以
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 3 年前。
我是 C# 的新手,正在尝试使用 ASP.Net GridView(框架 3.5),当 gridView 文本包含以下内容时,我发现了一个大问题: ñ/Ñ/á/Á/é/É/í/Í/ó/Ó/ú/Ú or
在 Java 中,我尝试编写一个正则表达式来匹配特殊类型的 HTTP URL: http:///# 所以字符串有 4 段: 字符串文字:“http://”;那么 任意 1 个以上字符的字符串;那么 字
当我写查询时,我在表中有“to”列 SELECT to FROM mytable mysql_error 返回错误,如果将单词to插入``引号,即 SELECT `to` FROM mytable 查
我遇到了一个问题。事实上,我使用越南语文本,我想找到每个包含大写字母(大写字母)的单词。当我使用“re”模块时,我的函数 (temp) 没有捕捉到像“Đà”这样的词。另一种方法 (temp2) 是一次
在我的文本中,我想用一个空格替换以下特殊字符: symbols = ["`", "~", "!", "@", "#", "$", "%", "^", "&", "*", "(", ")", "_",
我是一名优秀的程序员,十分优秀!