Нужен скрипт для редактирования файла - PullRequest
0 голосов
/ 10 ноября 2011
<?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',
    );
}

В логине, пароле и базе данных есть некоторые значения по умолчанию.Как мне написать скрипт для редактирования логина, пароля и базы данных?

Ответы [ 2 ]

2 голосов
/ 10 ноября 2011

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', поэтому оно не будет изменено.

, если вы хотите, вы можете поместить новое значение в переменную и передать в awk с -v.

edit

, если вы хотите изменить все значения (включая блок $ 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',
        );
    }
1 голос
/ 10 ноября 2011
    #!/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
    } 
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...