我想要阻止所有与此正则表达式模式不匹配的字符:[a-zA-Z0-9_-]
。
通常我会这样做:
preg_replace("[a-zA-Z0-9_-]", "", $var);
但显然这对我想要的东西产生了相反的效果。正则表达式中是否有NOT?如何删除任何与模式不匹配的字符?
感谢。
答案 0 :(得分:8)
此:
preg_replace("[a-zA-Z0-9_-]", "", $var);
除非输入字符串恰好是模式,否则甚至不会替换这些字符。通过使用[]
作为分隔符,它们与表达式本身的效果不同。您可以更改分隔符(例如:/
),或在模式中添加更多括号:
preg_replace("/[a-zA-Z0-9_-]/", "", $var); // this works
preg_replace("[[a-zA-Z0-9_-]]", "", $var); // this too
现在,取消[]
中的模式,您在开头使用^
:
preg_replace("/[^a-zA-Z0-9_-]/", "", $var);
您也可以使用不敏感修饰符i
来匹配小写(a-z
)和大写(A-Z
):
preg_replace("/[^a-z0-9_-]/i", "", $var); // same as above
答案 1 :(得分:0)
[^a-zA-Z0-9_-]
应该为你做。请注意括号内的^
。
答案 2 :(得分:0)
字符前面的^字符怎么样:
preg_replace( '[^a-zA-Z0-9_-]", "", $var);
答案 3 :(得分:0)
在正则表达式的范围元素中,如果第一个字符为^
,则它会反转范围(因此[^a-zA-Z0-9_-]
匹配任何不是字母数字,下划线或短划线的字符)
大多数类型的正则表达式都是如此