迭代内容并检索值

时间:2012-08-20 07:26:09

标签: php extract

我有一个像这样的属性列表:

1000 Rope Bend Ter
Labelle, FL 33935
Hendry County
15811 Hendry Isles Blvd
Clewiston, FL 33440
Hendry County

现在我需要提取第一行,并将其放在地址字段下的MySQL数据库中,然后提取城市(总是第二行并在其后面加逗号),提取状态和ZIP,将它们放在适当的MySQL列。

因此,基本上,一个地址分为3行,格式如上所示。地址,换行符,城市,州,ZIP,换行县(我不需要县信息)。

有人可以提示如何正确提取它吗?

1 个答案:

答案 0 :(得分:1)

修改 :更新了正则表达式

正则表达式/^([^ ]+)\s*(.+)\s+([^,]+),\s*([^ ]+)\s*(.+)\s*(.+)/im应该有效。

在PHP中使用它的方法是:

<?php
    $string = "1000 Rope Bend Ter\r\nLabelle, FL 33935\r\nHendry County\r\n15811 Hendry Isles Blvd\r\nClewiston, FL 33440\r\nHendry County";
    preg_match_all("/^([^ ]+)\s*(.+)\s+([^,]+),\s*([^ ]+)\s*(.+)\s*(.+)/im", $string, $matches);

    for ($i = 0; $i < count($matches[0]); $i++) {
        echo "Street number: " . $matches[1][$i] . "<br />";
        echo "Street name: " . $matches[2][$i] . "<br />";
        echo "City: " . $matches[3][$i] . "<br />";
        echo "State: " . $matches[4][$i] . "<br />";
        echo "Zip: " . $matches[5][$i] . "<br />";
        echo "County: " . $matches[6][$i] . "<br />";
        echo "<br /><br />";
    }
?>

<强>输出:

Street number: 1000
Street name: Rope Bend Ter 
City: Labelle
State: FL
Zip: 33935 
County: Hendry County

Street number: 15811
Street name: Hendry Isles Blvd 
City: Clewiston
State: FL
Zip: 33440 
County: Hendry County

如果您需要解释正则表达式,请说出来。