邮政编码到城市/州查找XML文件?

时间:2009-01-10 19:44:55

标签: linq zipcode

尝试查找我可以使用的XML文件代替查找数据库表,直到我们将Web主机切换到正确的数据库。

有人可以将我推荐给一个XML文件,其中的子元素包含子代码,状态和城市吗? E.g:

<zip code="98117">
    <state>WA</state>
    <city>Seattle</state>
</zip>

或者

<entry>
    <zip>98117</zip>
    <state>WA</state>
    <city>Seattle</city>
</entry>

我将在C#中使用LINQ来查询这些数据。

4 个答案:

答案 0 :(得分:1)

看看这个,它提供了几个不同的免费。

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

答案 1 :(得分:0)

免费邮政编码数据库位于:

http://www.populardata.com

我相信它是一个.CSV文件,但您可以很容易地将其转换为XML文件。

答案 2 :(得分:0)

以下是基于输入的邮政编码进行city.state自动填充的代码。

<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");
});

//]] GT;

以下是API - http://www.zipcodeapi.com/Examples#example1

答案 3 :(得分:0)

您可以通过XML请求内容。要直接以XML格式返回数据,您可以使用请求格式的.xml。

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

将回复

<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>

Api文档位于https://www.zipcodeapi.com/API