- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我有 150 多个 PHP 文件需要更改(将 ereg 更新为 preg_match)。我厌倦了手动更新它们,但它需要永远,我想确保我的所有替换都能在第一次工作。我该怎么做才能进行这种操作?
这是我的 ereg(i) 的一些例子
if(eregi("^[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}$", $ip)) { /* ... */}
if (eregi($regexp, $label, $match)) { /* ... */}
$string = eregi_replace("[[:space:]]+", ' ', $string);
谢谢
最佳答案
#!/bin/bash
perl -p -i -e "s/eregi_replace *\\( *\"([^\@]+?)(?<\!\\\\)\", */preg_replace(\"\@\\1\@i\", /g" $1
perl -p -i -e "s/eregi_replace *\\( *\'([^\@]+?)(?<\!\\\\)\', */preg_replace(\'\@\\1\@i\', /g" $1
perl -p -i -e "s/ereg_replace *\\( *\"([^\@]+?)(?<\!\\\\)\", */preg_replace(\"\@\\1\@\", /g" $1
perl -p -i -e "s/ereg_replace *\\( *\'([^\@]+?)(?<\!\\\\)\', */preg_replace(\'\@\\1\@\', /g" $1
perl -p -i -e "s/eregi *\\( *\"([^\@]+?)(?<\!\\\\)\", */preg_match(\"\@\\1\@i\", /g" $1
perl -p -i -e "s/eregi *\\( *\'([^\@]+?)(?<\!\\\\)\', */preg_match(\'\@\\1\@i\', /g" $1
perl -p -i -e "s/ereg *\\( *\"([^\@]+?)(?<\!\\\\)\", */preg_match(\"\@\\1\@\", /g" $1
perl -p -i -e "s/ereg *\\( *\'([^\@]+?)(?<\!\\\\)\', */preg_match(\'\@\\1\@\', /g" $1
这是我使用的一个小 bash 脚本。比我有更多时间的人可能可以将所有这些压缩成更少(1?)的正则表达式,但它应该可以解决问题。请随意将 @
替换为您选择的分隔符。只需将其粘贴到一个文件中,chmod +x
它,然后调用它,将文件作为参数传递。
如果你需要大量使用它,这样的东西就足够了:
find /path/to/your/project -name '*.php' -exec foo {} \;
foo
是您为 bash 脚本命名的地方。
注意:这并不完美,因此您仍然需要手动更改它遗漏的任何边缘案例,但它仍然会为您节省大量工作。另请注意,这会进行就地文件编辑。
关于PHP 全局替换 ereg(i)(_replace),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7575455/
我有一个命名元组类型的子类: class User(namedtuple('User', ['first_name'])): __slots__ = () def __new__(cl
我有 150 多个 PHP 文件需要更改(将 ereg 更新为 preg_match)。我厌倦了手动更新它们,但它需要永远,我想确保我的所有替换都能在第一次工作。我该怎么做才能进行这种操作? 这是我的
我在实现 namedtuple._replace() 时遇到了问题,所以我直接从文档中复制了代码: Point = namedtuple('Point', 'x,y') p = Point(x=11,
我可以使用变量引用 namedtuple 字段名吗? from collections import namedtuple import random Prize = namedtuple("Priz
拿这段代码: >>> import urlparse >>> parts = urlparse.urlparse('http://docs.python.org/library/') >>> part
我是一名优秀的程序员,十分优秀!