我有一个像这样的属性列表:
1000 Rope Bend Ter
Labelle, FL 33935
Hendry County
15811 Hendry Isles Blvd
Clewiston, FL 33440
Hendry County
现在我需要提取第一行,并将其放在地址字段下的MySQL数据库中,然后提取城市(总是第二行并在其后面加逗号),提取状态和ZIP,将它们放在适当的MySQL列。
因此,基本上,一个地址分为3行,格式如上所示。地址,换行符,城市,州,ZIP,换行县(我不需要县信息)。
有人可以提示如何正确提取它吗?
答案 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
如果您需要解释正则表达式,请说出来。