正则表达式仅允许字母数字、逗号、连字符、下划线和分号
我已经有了一些工作代码,但我需要有人帮助解释为什么它可以工作(如果可以的话)!
我使用 PHP 来替换字符串中的任何内容,如果它不是 az、AZ、0-9、逗号、分号、下划线或连字符(最终应表示单个用户名或逗号/分号分隔)用户名列表)。
以下有效:
$data = preg_replace('/[^,;a-zA-Z0-9_-]/s', '', $data);
但以下无效:
$data = preg_replace('/[^a-zA-Z0-9_-,;]/s', '', $data);
为什么只有当逗号和分号开头时才有效?将它们放在最后似乎会破坏一些东西(这是我在遇到 /[^a-zA-Z0-9_-]/s 时最初尝试的方法。
顺便说一句,我还使用以下内容来修剪任何 尾随分号(复数)或逗号(复数),有人可能能够建议一种更有效和/或更优雅的方法来做到这一点?:
if(preg_match('/;$/', $data))
{
$data = rtrim($data, ';' );
}
if(preg_match('/,$/', $data))
{
$data = rtrim($data, ',' );
}
感谢您的帮助:)
I've already got a bit of working code but I need someone to help explain why it works if they can!
I am using PHP to replace anything in a string if it is not either a-z, A-Z, 0-9, a comma, a semicolon, an underscore or a hyphen (which ultimately should represent either a single username, or a comma/semicolon separated list of usernames).
The following works:
$data = preg_replace('/[^,;a-zA-Z0-9_-]/s', '', $data);
But the following does not:
$data = preg_replace('/[^a-zA-Z0-9_-,;]/s', '', $data);
Why will this only work when the comma and semicolon are at the start? Putting them at the end seems to break things (this is what I tried initially when I came across /[^a-zA-Z0-9_-]/s.
As an aside, I am also using the following to trim any trailing semicolons (plural) or commas (plural) and someone may be able to suggest a more efficient and/or elegant way to do this?:
if(preg_match('/;$/', $data))
{
$data = rtrim($data, ';' );
}
if(preg_match('/,$/', $data))
{
$data = rtrim($data, ',' );
}
Thanks for any help :)
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

这不是导致你的问题的逗号和分号;这是连字符。查看字符类的各个部分并考虑它们的含义:
从
_
到,
没有明显的进展,因此正则表达式引擎不确定如何处理它。在字符类中,如果您希望按字面解释连字符,则它需要位于类的开头或结尾(或使用反斜杠转义)。因此,这些中的任何一个都可以工作:至于修剪末端,您可以在一个正则表达式替换中完成所有这些操作:
It's not the comma and semicolon causing your problem; it's the hyphen. Look at the parts of your character class and consider what they mean:
There's no clear progression from
_
to,
, so the regex engine isn't sure what to make of this. In character classes, if you want a hyphen to be interpreted literally, it needs to be at the very beginning or end of the class (or escaped with a backslash). So any of these will work:As for trimming off the end, you can do all of this in one regex replace: