Codice postale nel file XML di ricerca città / stato?
Domanda
Sto cercando di trovare un file XML che posso usare al posto di una tabella di database di ricerca fino a quando il nostro web hosting non viene commutato nel DB giusto.
Qualcuno può riferirmi a un file XML con elementi i cui figli hanno codici postali, stati e città? Per esempio:.
<zip code="98117">
<state>WA</state>
<city>Seattle</state>
</zip>
o
<entry>
<zip>98117</zip>
<state>WA</state>
<city>Seattle</city>
</entry>
Userò LINQ in C # per interrogare questi dati.
Soluzione
Dai un'occhiata a questo, fornisce molti diversi gratuiti.
Altri suggerimenti
Esiste un database di codici postali gratuito disponibile all'indirizzo:
Credo che sia un file .CSV ma potresti convertirlo in un file XML abbastanza facilmente.
Ecco il codice per eseguire il riempimento automatico di city.state in base a un codice postale inserito.
<script type="text/javascript">//<![CDATA[
$(function() {
// IMPORTANT: Fill in your client key
var clientKey = "js-9qZHzu2Flc59Eq5rx10JdKERovBlJp3TQ3ApyC4TOa3tA8U7aVRnFwf41RpLgtE7";
var cache = {};
var container = $("#example1");
var errorDiv = container.find("div.text-error");
/** Handle successful response */
function handleResp(data)
{
// Check for error
if (data.error_msg)
errorDiv.text(data.error_msg);
else if ("city" in data)
{
// Set city and state
container.find("input[name='city']").val(data.city);
container.find("input[name='state']").val(data.state);
}
}
// Set up event handlers
container.find("input[name='zipcode']").on("keyup change", function() {
// Get zip code
var zipcode = $(this).val().substring(0, 5);
if (zipcode.length == 5 && /^[0-9]+$/.test(zipcode))
{
// Clear error
errorDiv.empty();
// Check cache
if (zipcode in cache)
{
handleResp(cache[zipcode]);
}
else
{
// Build url
var url = "http://www.zipcodeapi.com/rest/"+clientKey+"/info.json/" + zipcode + "/radians";
// Make AJAX request
$.ajax({
"url": url,
"dataType": "json"
}).done(function(data) {
handleResp(data);
// Store in cache
cache[zipcode] = data;
}).fail(function(data) {
if (data.responseText && (json = $.parseJSON(data.responseText)))
{
// Store in cache
cache[zipcode] = json;
// Check for error
if (json.error_msg)
errorDiv.text(json.error_msg);
}
else
errorDiv.text('Request failed.');
});
}
}
}).trigger("change");
});
//]] >
Ecco l'API - http://www.zipcodeapi.com/Examples#example1 .
Puoi richiedere il contenuto in XML tramite Per recuperare i dati direttamente in XML puoi usare .xml nel formato nella richiesta.
Risponderà con
<response>
<zip_code>90210</zip_code>
<lat>34.100501</lat>
<lng>-118.414908</lng>
<city>Beverly Hills</city>
<state>CA</state>
<timezone>
<timezone_identifier>America/Los_Angeles</timezone_identifier>
<timezone_abbr>PDT</timezone_abbr>
<utc_offset_sec>-25200</utc_offset_sec>
<is_dst>T</is_dst>
</timezone>
<acceptable_city_names/>
</response>
I documenti Api sono disponibili all'indirizzo https://www.zipcodeapi.com/API