草庐IT

regex_replace

全部标签

php - 用 php regex 替换方括号之间的子字符串

这是我正在处理的子字符串[sitetree_link%20id=2]我需要用空格替换所有出现在[]之间的%20。但很明显,如果[]大括号外有%20s,请不要管它们......我现在正在学习正则表达式,但这个似乎很难。有人对此有一个super智能的正则表达式吗?谢谢:) 最佳答案 你可以试试这个$result=preg_replace('/(\[[^]]*?)(%20)([^]]*?\])/m','$1$3',$subject);解释(#Matchtheregularexpressionbelowandcaptureitsmatchi

php/html : replace html closing tags with newlines

我在网上抓取html,当我使用phpstrip_tags时,它会将整个html压缩成一行,删除所有结构。我想通过用换行符替换关闭的h、p和br标记来保留结构。pregreplace是最好的解决方案吗?一旦我替换了所有结束标签,我将运行一个strip标签,但这样我就有了一个基本结构。 最佳答案 $str='somehtml';$tags=array('','','','','','','','','','','');$str=str_replace($tags,"\n",$str);//thenstriptags

php - 用于检查 URL 是否为短 URL 的 Regex/php 代码

我正在尝试创建一个php函数来检查传递的URL是否为短URL。像这样:/***CheckifaURLisashortURL**@paramstring$url*returnbool*/function_is_short_url($url){//Codegoeshere}我知道更简单和可靠的方法是检查301重定向,但此功能旨在保存外部请求仅用于检查。该函数也不应检查URL缩短器列表,因为这将是一种可扩展性较差的方法。我在想的一些可能的检查也是如此:URL总长度-最多30个字符最后一个“/”后的URL长度-最多10个字符协议(protocol)(http://)后“/”的数量-最多2主机的

php - Preg_replace BBCode 链接

我有这个bbcode:[url=http://www.youtube.com/watch?v=h1bIEK1h150]IfIofferyoumysoul[/url]例如。我怎样才能把它变成这样:IfIofferyoumysoul 最佳答案 你需要一个正则表达式。考虑到bbcode可以有文本URL或只有URL,您将需要两个语句:$message=preg_replace('@\[url=([^]]*)\]([^[]*)\[/url\]@','$2',$message);$message=preg_replace('@\[url\]([

php - preg_replace 除字符串开头的 + 以外的所有非数字字符

假设输入字符串+123-321+123345,使用PHP的正则表达式函数我想删除所有非数字([^\d])字符,除了开头的+字符。+可能存在也可能不存在,因此给定字符串123-321+123345结果应该相同(123321123345)。目前的解决方法是检查+,然后运行​​preg_replace('/[^\d]+/','',$string),但我确信必须有一个纯正则表达式的解决方案来解决这个问题。谢谢! 最佳答案 试试这个/(?\D与[^\d]相同(?是一个负向后视,确保在非数字之前没有字符串的开头。这个表达式将匹配所有不是字符串开

php regex - 干净的文件名

我正在寻找优雅的正则表达式来清理括号,内容看起来像文件名。[Nibhjusto]elitNulla[link.pdf]auctoripsummolestie(link.pdf)Condimentumeuismodnon[link.xls](link.xls)[link.doc](link.doc)tempusIn[Curabitur]et结果应该是:NibhjustoelitNullaauctoripsummolestieCondimentumeuismodnontempusInCurabituret我相信一定有一个捷径可以做到这一点。(文件的意思很简单-包括点。不需要句子检查。)感谢

php regex删除CSS供应商前缀 hell

我正在尝试清理我的CSS文档以仅删除那些带有供应商前缀的行:-webkit-......;-o-.....;-ms-......;-khtml-......;-moz-......;如您所见,所有行都具有相同的模式并以分号结尾,只是供应商不同。到目前为止,我尝试了一个一个地搜索,但应该有更好的方法来实现这一点:preg_match("/(-webkit.*;)/",$css,$webkit);$css=str_replace($webkit[1],'',$css);//...etc任何提示将不胜感激。谢谢更新:原因是我将使用http://leaverou.github.com/pref

php - str_replace 不会替换阿拉伯字符

';$patterns=array("على","مع");$replacements=array("","");$r_string=str_replace($patterns,$replacements,$utf8_string);//echo$r_string;print_r($r_string);echo'';//$words=preg_split("/(|مع|على)/",$r_string);$words=explode("",$r_string);$num=count($words);echo'Thereare'.$num.'words.';?>我有这个代码来计算阿拉伯语

php - 为什么我的 htmlspecialchars 和 str_replace 不工作?

对于我的例子,请访问http://jflaugher.mystudentsite.net/cmweb241/cmweb241_lab2.html我只需要使用htmlspecialchars和str_replace函数来删除双引号和单引号。为什么这对我不起作用?我对PHP很陌生:/YourUsernameis:$username.";echo"YourPasswordis:$password.";echo"YourCommentwas:$comment.";?> 最佳答案 按照AlexLunix指定的相反顺序使用它$username=

php - 在 PHP 中使用 REGEX 选择样式属性

我希望仅在php中使用正则表达式获取样式属性及其内容。例如输入期望的输出style="float:left;"我尝试过的:这似乎返回了整个图像,我不确定为什么。我不擅长正则表达式。$img='';preg_match('/(]+)style=".*?"/i',$img,$match);返回:[0]=>Array([0]=>谁有任何指点?干杯。 最佳答案 你几乎是正确的,你只需要捕获你想要的部分,将它括在括号中。您目前正在捕获错误的部分:$img='';preg_match('/]+(style=".*?")/i',$img,$mat