需要一个脚本来编辑文件


Need a script to edit file

<?php
class DATABASE_CONFIG {
    public $default = array(
        'datasource' => 'Database/Mysql',
        'persistent' => false,
        'host' => 'hostname',
        'login' => 'username',
        'password' => 'password',
        'database' => 'database_name',
        'prefix' => '',
        //'encoding' => 'utf8',
    );
    public $test = array(
        'datasource' => 'Database/Mysql',
        'persistent' => false,
        'host' => 'hostname',
        'login' => 'username',
        'password' => 'password',
        'database' => 'database_name',
        'prefix' => '',
        //'encoding' => 'utf8',
    );
}

在登录名、密码和数据库中有一些默认值。如何编写脚本编辑登录名,密码和数据库?

php文件包含您的示例文本:

kent$  awk '/login/{l++;if(l>1)gsub(/root/,"newLogin");} 
        /password/{p++;if(p>1)gsub(/xxx/,"newPwd");} 
        /database/{d++;if(d>1)gsub(/xxx/,"newDB");} 1' php
<?php
class DATABASE_CONFIG {
    public $default = array(
        'datasource' => 'Database/Mysql',
        'persistent' => false,
        'host' => 'localhost',
        'login' => 'root',
        'password' => 'xxx',
        'database' => 'xxx',
        'prefix' => '',
        //'encoding' => 'utf8',
    );
    public $test = array(
        'datasource' => 'Database/Mysql',
        'persistent' => false,
        'host' => 'localhost',
        'login' => 'newLogin',
        'password' => 'newPwd',
        'database' => 'cake_test_db',
        'prefix' => '',
        //'encoding' => 'utf8',
    );
}

只改变$default块之后的块。并且,只会更改的默认值。例如,在你的$test中,'database' => 'cake_test_db'的值不是默认的'xxx',所以它不会被改变。

如果你愿意,你可以在变量中添加新的值,并通过-v传递给awk。

编辑

如果你想改变所有的值,(包括$default块),会更容易,检查下面的行:(和上面一样,只有默认值(root, xxx,xxx)会被改变。

kent$    awk '/login/{gsub(/root/,"newLogin");}                                                                                          
            /password/{gsub(/xxx/,"newPwd");}                                                                                            
            /database/{gsub(/xxx/,"newDB");} 1' php                                                                                      
<?php
class DATABASE_CONFIG {
    public $default = array(
        'datasource' => 'Database/Mysql',
        'persistent' => false,
        'host' => 'localhost',
        'login' => 'newLogin',
        'password' => 'newPwd',
        'database' => 'newDB',
        'prefix' => '',
        //'encoding' => 'utf8',
    );
    public $test = array(
        'datasource' => 'Database/Mysql',
        'persistent' => false,
        'host' => 'localhost',
        'login' => 'newLogin',
        'password' => 'newPwd',
        'database' => 'cake_test_db',
        'prefix' => '',
        //'encoding' => 'utf8',
    );
}

edit2

这适用于您的新示例。

 sed '/login/{s/username/newLOGIN/}; /password/{s/password/newPWD/2}; /database/{s/database_name/newDB/}' php
    <?php
    class DATABASE_CONFIG {
        public $default = array(
            'datasource' => 'Database/Mysql',
            'persistent' => false,
            'host' => 'hostname',
            'login' => 'newLOGIN',
            'password' => 'newPWD',
            'database' => 'newDB',
            'prefix' => '',
            //'encoding' => 'utf8',
        );
        public $test = array(
            'datasource' => 'Database/Mysql',
            'persistent' => false,
            'host' => 'hostname',
            'login' => 'newLOGIN',
            'password' => 'newPWD',
            'database' => 'newDB',
            'prefix' => '',
            //'encoding' => 'utf8',
        );
    }
    #!/usr/bin/awk -f
    BEGIN {   FS="'"   
         usr[0] ="usr1"   ;  usr[1] = "user2" 
        pass[0] ="pass1"  ; pass[1] = "pass2" 
          db[0] ="db1"    ;   db[1] = "db2"
    }  
    {
    if ($2 == "login") { 
        $0="'t'login' => '" usr[u] "',"
        u++
    } 
    if ($2 == "password") { 
        $0="'t'password' => '" pass[p] "',"
        p++
    }
    if ($2 == "database") { 
        $0="'t'database' => '" db[d] "',"
        d++
    }
     print
    }