He creado un formulario html en el que puede introducir suDirección en una sola cadena. ¿Cómo puedo extraer el número de la calle, el nombre de la calle y el tipo de calle (media luna, carretera, calle, etc.) en PHP? No estoy seguro de la longitud de la cadena que ingresarán y es posible que no extraiga la información correcta.
Por favor ayúdenme ya que soy nuevo en la codificación en PHP.
Aquí está mi código a continuación:
$address = $_POST["address"];
echo "Your address is: $address <br>";
$addressSubstring = substr($address,0 , 15);
echo "Address: $addressSubstring <br>";
$strNumber = substr($addressSubstring, 0, 2);
$strName = substr($addressSubstring, 2, 8);
$strType = substr($addressSubstring, 8, 15);
echo "Your street number is: $strNumber <br>";
echo "Your street name is: $strName <br>";
echo "Your street type is: $strType <br>"
Respuestas
0 para la respuesta № 1Teniendo en cuenta que los tipos de carretera son "crescent | road | street":
El uso de expresiones regulares puede resolver el problema:
<?php
$address = "43 Willow Street"; // $_POST["address"] or "35 Hanover Crescent & 52 Longford Road";
preg_match_all("/(d+)(.+?)(crescent|road|street)/i", $example, $out_arr);
// $no_of_addresses_found = count($out_arr[0]); // in case of future improvements
$strNumber = $out_arr[1][0]; // 43
$strName = trim($out_arr[2][0]); // Willow
$strType = $out_arr[3][0]; // Street
echo "Your street number is: $strNumber <br>";
echo "Your street name is: $strName <br>";
echo "Your street type is: $strType <br>"
1 para la respuesta № 2
No puede confiar en obtener subcadenas en posiciones y longitudes fijas como en su código, ya que cambiarán cada vez.
Sin usar ninguna API o AI, lo mejor que puedes hacer es crear una matriz con tipos de caminos (y sus abreviaturas) y verificar si alguna de esas palabras está en la cadena.
Para eso puedes usar puntales para cada palabra o expresiones regulares que coincidan.
A continuación, puede eliminar esa palabra de la cadena,y obtener la posición del primer espacio usando strpos nuevamente. Luego use esa posición para obtener la subcadena antes del espacio (número de calle) y la subcadena después del espacio (nombre de la calle).