繁体   English   中英

如何使用 PHP 分隔街道名称和门牌号码?

[英]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.

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