[英]How do I seperate street names and house numbers with PHP?
在德国,我们有街道名称和门牌号码。 我使用一个数据库,其中两者都存储在一个列中(例如“Arnoldstraße 12”),我想将它们分成单个变量。
我有这个代码:
$street= $row[2]; //This row is from an array with values of the database. The other rows are submitted perfectly.
preg_match('/([^\d]+)(\d+.*)/', $street, $matches);
$street_new = trim($matches[1]);
$house_number= trim($matches[2]);
while ($row = $jobDB->fetchArray($result)) {
$this->setReturnValue('strasse', $street_new);
$this->setReturnValue('hausnummer', $house_number);
return;
}
之后,我使用 JS 代码将其(以及更多值)放入网站上的表单中。 其他值没有问题,只是缺少街道名称和门牌号码。
这是JS代码:
var auto_complete = function() {
var kontonr = jr_get_value('tb_kundennummer');
jr_execute_dialog_function('autoComplete', {kontonummer: kontonr}, mySuccessCallback);
}
var mySuccessCallback = function(returnObject) {
jr_set_value('tb_kunde_strasse', returnObject.result.street_new);
jr_set_value('tb_kunde_hausnummer', returnObject.result.house_number);
}
我究竟做错了什么?
先感谢您: :)
好的,我找到了解决方案。 将代码添加到while循环后,它运行良好:
while ($row = $jobDB->fetchArray($result)) {
$street= $row[2];
preg_match('/([^\d]+)(\d+.*)/', $street, $matches);
$street= trim($matches[1]);
$house_number= trim($matches[2]);
$this->setReturnValue('strasse', $street);
$this->setReturnValue('hausnummer', $house_number);
return;
}
我不是一个开发人员,但可能是因为 $row 只有在 fetchArray 之后调用时才有效。 但我不确定。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.