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.

È stato utile?

Soluzione

Dai un'occhiata a questo, fornisce molti diversi gratuiti.

https://stackoverflow.com/questions/24471/zip-code-database

Altri suggerimenti

Esiste un database di codici postali gratuito disponibile all'indirizzo:

http://www.populardata.com

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.

https://www.zipcodeapi.com/rest/RbdapNcxbjoCvfCv4N5iwB3L4beZg017bfiB2u9eOxQkMtQQgV9NxdyCoNCENDMZ/ info.xml / 90210 / gradi

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

Autorizzato sotto: CC-BY-SA insieme a attribuzione
Non affiliato a StackOverflow
scroll top