我想将匹配结果的特定部分存储为稍后用于替换的变量.我想把它保存在一个班轮中而不是找到我需要的变量.
在配置apache并使用mod_rewrite时,您可以指定要用作变量的模式的特定部分,如下所示:
RewriteRule ^www.example.com/page/(.*)$http://www.example.com/page.PHP?page=$1 [R=301,L]
括号内包含的模式匹配部分存储为$1以供日后使用.因此,如果网址为www.example.com/page/home,则会将其替换为www.example.com/page.PHP?page=home.所以比赛的“主场”部分保存在$1中,因为它是括号内部模式的一部分.
我希望像sed命令这样的功能,我需要自动替换sql转储文件中的许多字符串,如果在每个create table之前存在命令,则添加drop table,但是我需要知道表名来执行此操作,所以如果转储文件包含以下内容:
... CREATE TABLE `orders` ...
我需要运行类似的东西:
cat dump.sql | sed "s/CREATE TABLE `(.*)`/DROP TABLE IF EXISTS $1\N CREATE TABLE `$1`/g"
得到的结果:
... DROP TABLE IF EXISTS `orders` CREATE TABLE `orders` ...
我在sed命令中使用mod_rewrite语法作为我正在尝试做的事情的逻辑示例.
有什么建议?
sed '/CREATE TABLE \([^ ]*\)/ s//DROP TABLE IF EXISTS \1; &/'
查找CREATE TABLE语句并捕获表名.将其替换为“DROP TABLE IF EXISTS”和表名,加上分号以终止语句,以及匹配的内容副本以保留CREATE TABLE语句.
这是经典的sed表示法.由于你正在使用bash,你有可能使用GNU sed并且需要添加–posix来使用这种表示法,或者你需要使用脚本来使用GNU的非标准sed regex.我也没有尝试在输出中插入换行符.你可以用GNU sed做到这一点,如果它对你来说足够重要的话.
关键点是括号(通常需要使用反斜杠进行转义)是捕获机制,反斜杠数是替换机制.