简体   繁体   中英

How to split string with date as delimiter?

Could you help me with splitting large string into substrings?

Scenario: In one of fields inside MySQL table I've got string in which there is an activity log in following format:

yyyy-mm-dd hh:mm:ss - Name1 Surname1 - Activity1
yyyy-mm-dd hh:mm:ss - Name2 Surname2 - Activity2
yyyy-mm-dd hh:mm:ss - Name3 Surname3 - Multiline Activity1
Multiline Activity2
Multiline Activity3
yyyy-mm-dd hh:mm:ss - Name4 Surname4 - Activity4

Question:

How can I split the above data into array like this:

id       date                    name                    activity
1        yyyy-mm-dd hh:mm:ss     Name1 Surname1          Activity1
2        yyyy-mm-dd hh:mm:ss     Name2 Surname2          Activity2
3        yyyy-mm-dd hh:mm:ss     Name3 Surname3          Multiline Activity 1, Multiline Activity2, Multiline Activity 3
4        yyyy-mm-dd hh:mm:ss     Name4 Surname4          Activity4

using PHP or MySQL query?

I know it could be done somehow, but unfortunately by knowledge of PHP/MySQL doesn't allow me to parse text with variable delimiter (date), or maybe there is another way?

You can try with preg_split :

$string = <<<STR
2013-06-04 12:12:12 - Name1 Surname1 - Activity1
2013-06-04 12:12:12 - Name2 Surname2 - Activity2
2013-06-04 12:12:12 - Name3 Surname3 - Multiline Activity1
Multiline Activity2
Multiline Activity3
2013-06-04 12:12:12 - Name4 Surname4 - Activity4
STR;

$arr = preg_split("/(\d{4}-\d{2}-\d{2} \d{2}:\d{2}:\d{2}) - (.*) - (.*)[\r\n]?/", $string, null, PREG_SPLIT_DELIM_CAPTURE);

$arr = array_filter($arr);

print_r($arr);

Output:

Array
(
    [1] => 2013-06-04 12:12:12
    [2] => Name1 Surname1
    [3] => Activity1
    [5] => 2013-06-04 12:12:12
    [6] => Name2 Surname2
    [7] => Activity2
    [9] => 2013-06-04 12:12:12
    [10] => Name3 Surname3
    [11] => Multiline Activity1
    [12] => Multiline Activity2
Multiline Activity3

    [13] => 2013-06-04 12:12:12
    [14] => Name4 Surname4
    [15] => Activity4
)

Example for a real usage:

$i = -1; 
$result = array();

foreach($arr as $value) {
    if(preg_match("/(\d{4}-\d{2}-\d{2} \d{2}:\d{2}:\d{2})/", $value)) {
        // 1st element - datetime
        $i++;
        $result[$i]['datetime'] = $value;
    } elseif(!isset($result[$i]['name'])) {
        // 2nd element - name
        $result[$i]['name'] = $value;
    } else {
        // 3rd element - activities separated by comma
        if(!isset($result[$i]['activities'])) {
            $result[$i]['activities'] = $value;
        } else {
            $result[$i]['activities'] .= ', ' . $value;        
        }
    }
}

print_r($result);

Output:

Array
(
    [0] => Array
        (
            [datetime] => 2013-06-04 12:12:12
            [name] => Name1 Surname1
            [activities] => Activity1
        )

    [1] => Array
        (
            [datetime] => 2013-06-04 12:12:12
            [name] => Name2 Surname2
            [activities] => Activity2
        )

    [2] => Array
        (
            [datetime] => 2013-06-04 12:12:12
            [name] => Name3 Surname3
            [activities] => Multiline Activity1
, Multiline Activity2
Multiline Activity3

        )

    [3] => Array
        (
            [datetime] => 2013-06-04 12:12:12
            [name] => Name4 Surname4
            [activities] => Activity4
        )

)

循环遍历MySQL结果,并针对每一行执行以下操作:

$row = explode(' - ', $row);

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM