前言

作为一个很挫的C#新手总喜欢自己写点儿不着边际的东西,本人是个新手加菜鸟,写B/S的,工作中,任务完成了,空闲下来,总想继续学点儿什么,由此触发了本篇文章了。个人一直认为,.NET中,C/S所要求的技术含量要高得多,需要的知识也多得多。所以想多多研究研究。菜鸟文章!

环境

.NET3.5 + VS2010 + Geocoding API v2.0 +httpwebrequest/httpwebresponse

软件截图

这是软件总图,很简单,就几个按钮。。。

这里编写了一个批量导入Excel文件的功能,导入的Excel表内容如下:

导入Excel后,点击解析,解析出该公司的地理位置、经纬度、精确度、附近地标 and so on~~

解析完成后,支持将结果导出到Excel文件,导出的结果如下图:

主要是学习百度地图API、多线程的,所以没有精心设计皮肤,很朴素啦~~~

代码部分

百度地图API

接下来说说是如何实现的,其实原理很简单(我也不会难的。囧。),先调用百度API接口(正向解析),将公司名发送过去,然后会返回一段Json,里面包含了该地址的经纬度,然后继续调用API(逆向解析),将经纬度发送过去,返回的Json中就包含了地理位置还有一系列其他内容,通过截取之类的操作就得到了我需要的内容。

        /// <summary>
/// 地址逆向解析
/// </summary>
/// <param name="AddressName"></param>
public DataRow FindAddress(string AddressName, int i, DataRow dr)
{
try
{
string retString = HttpPost(string.Format("http://api.map.baidu.com/geocoder/v2/?ak=秘钥&callback=renderOption&output=json&address={0}&city=北京市&precise=1", AddressName));
retString = retString.Remove(, ).TrimEnd(')') + "\r\n";
string[] strs1 = retString.Split('{');
string[] strs2 = strs1[].Split(',');
string str3 = strs2[].Split(':')[];
string str4 = strs2[].Split(':')[].TrimEnd('}');
string str5 = strs2[].Split(':')[];
this.t_returnString.AppendText("经度:" + str3 + "\r\n" + "纬度:" + str4 + "\r\n" + "精确度:" + str5 + "\r\n");
string retLocad = HttpPost(string.Format("http://api.map.baidu.com/geocoder/v2/?ak=秘钥&callback=renderReverse&location={0}&output=json&pois=0", str4 + "," + str3));
//this.t_returnString.AppendText(retLocad + "\r\n");
string[] strs1_1 = retLocad.Split('{');
string[] strs2_1 = strs1_1[].Split(',');
string str3_1 = strs2_1[].Split(':')[];
string str4_1 = strs2_1[].Split(':')[] + "、" + strs2_1[] + "、" + strs2_1[];
this.t_returnString.AppendText("地理位置:" + str3_1 + "\r\n");
this.t_returnString.AppendText("附近地标:" + str4_1 + "\r\n");
this.t_returnString.ScrollToCaret();//滚动到光标处
dr["地理位置"] = str3_1;
dr["附近地标"] = str4_1;
dr["可信度"] = str5;
}
catch (Exception)
{
this.t_returnString.AppendText("暂无" + "\r\n");
}
return dr;
}

 多线程

当我完成百度地图部分后,我决定给自己的小软件加入批量解析功能,于是乎,出现了导入和导出Excel的功能,这个功能这里不多说,我的博客里面目前为止,基本上都是导入导出(继续 。囧囧。)。

当完成批量功能后,发现一执行解析,软件就假死状态,突然想起要用多线程。以前没用过多线程,继续百度一下,这方面的内容博客园里面挺多的。

        private void b_toExcel_Click(object sender, EventArgs e)
{
this.t_txtInfo.Enabled = false;
this.button1.Enabled = false;
this.b_openexcel.Enabled = false;
this.b_toExcel.Enabled = false;
WhileDataTable = ToDataTable(this.tb_url.Text, , true);
//多线程启动
ThreadStart startDownload = new ThreadStart(WhileFunc);
Thread downloadThread = new Thread(startDownload); //实例化要开启的新类
downloadThread.IsBackground = true;
downloadThread.Start();//开启线程
}

经过上面的部分是启动多线程的代码,意外的发现,多线程其实很好弄。

不过,再次遇到问题,发现交给线程处理的方法,不能传递值进行,也就是需要进行线程资源共享,继续百度!

这里,我使用委托、创建类级变量共享资源,具体代码如下(不知道是否理解错了,若是有错误,希望能提点一二):

        private delegate void DoDataDelegate();  //创建委托
private DataTable WhileDataTable = null; //全局变量
private DataTable ReturnTable = null;
public void WhileFunc()
{
if (progressBar1.InvokeRequired)
{
DoDataDelegate d = WhileFunc;
progressBar1.Invoke(d, null);
}
else
{
ReturnTable = new DataTable();
ReturnTable.Columns.Add("公司名", typeof(string));
ReturnTable.Columns.Add("可信度", typeof(string));
ReturnTable.Columns.Add("地理位置", typeof(string));
ReturnTable.Columns.Add("附近地标", typeof(string)); progressBar1.Maximum = (int)WhileDataTable.Rows.Count;
for (int i = ; i < (int)WhileDataTable.Rows.Count; i++)
{
DataRow row = ReturnTable.NewRow();
progressBar1.Value = i + ;
row["公司名"] = WhileDataTable.Rows[i][];
this.t_returnString.AppendText("\r\n" + WhileDataTable.Rows[i][] + ":\r\n");
row = FindAddress(WhileDataTable.Rows[i][].ToString(), i, row); Application.DoEvents();
ReturnTable.Rows.Add(row);
if (progressBar1.Value == progressBar1.Maximum)
{
this.Enabled = true;
if (MessageBox.Show("数据解析完成,是否生成Excel文档?", "消息", MessageBoxButtons.OKCancel, MessageBoxIcon.Question, MessageBoxDefaultButton.Button2) == DialogResult.OK)
{
CreateSheet("地址解析结果", ReturnTable);
}
}
}
}
}

到这里,测试,OK!

UI线程和执行方法的线程分离了,软件UI不会在执行解析方法的时候假死了!

后记

其实,这个软件有很大问题的,百度的API并不能准确的返回查询的公司信息,百度也不可能将所有的公司信息加载到他们的数据库里面去的。所以精确度有限,实用性差,练手吧!不过,在这个软件的启发下,我萌生了继续开发的想法,这次索性换了一种方法,决定用爬虫技术+多线程去爬行百度检索出来的网站,再通过网站内容检索、跳转找到这些公司的主页、或者相关页面,进一步得到该公司的准确地址信息!

网络爬虫的资料网上不是很多,大部分都是自己琢磨的,某些地方肯定会存在问题,软件我也写的差不多了,确实能够找到公司的具体地理位置,但是还是存在许多问题的。

先贴一张图,以后有时间完善了,发篇博文上来!

相关资料:

百度地图Geocoding API v2.0:http://developer.baidu.com/map/webservice-geocoding.htm

这里发上源代码(VS2010工程):http://download.csdn.net/detail/a406502972/7963037

Winform实现用多线程、百度地图API解析某公司的物理地址的更多相关文章

  1. 利用百度地图API和群蚁算法,对TSP问题进行模拟与求解

    前言 最近由于换了工作,期间也有反思和总结上家公司的得失,总觉得有什么事情当初可以完成或者完成得更好,其中TSP问题就是其中之一.当初在开发一个仓配系统的时候,有一个线路排程的需求,当时自己简单在纸上 ...

  2. Python调用百度地图API实现批量经纬度转换为实际省市地点(api调用,json解析,excel读取与写入)

    1.获取秘钥 调用百度地图API实现得申请百度账号或者登陆百度账号,然后申请自己的ak秘钥.链接如下:http://lbsyun.baidu.com/apiconsole/key?applicatio ...

  3. java 基于百度地图API GPS经纬度解析地址

    首先这是百度地图api 的接口地址,基于接口的参数,不过多介绍,其中都提供相应的介绍: http://lbsyun.baidu.com/index.php?title=webapi/guide/web ...

  4. 百度地图API使用方法详解

    最近做了个项目,其中项目中有个需求需要用到百度地图进行导航,通过查阅相关资料参考百度地图api完成了一个例子. API地址:http://developer.baidu.com/map/jsdemo. ...

  5. ***微信LBS地理位置开发+百度地图API(地理位置和坐标转换)

    微信公众平台开发 - 获取用户地理位置 本文介绍在微信公众平台上如何使用高级接口开发获取用户地理位置的功能. 一.获取用户地理位置接口 开通了上报地理位置接口的公众号,用户在关注后进入公众号会话时,会 ...

  6. 百度地图API 简单使用

    最近项目上需要用到百度地图进行导航,参考百度地图API完成一个例子.API地址:http://developer.baidu.com/map/jsdemo.htm#a1_2 <!DOCTYPE ...

  7. 【百度地图API】JS版本的常见问题

    1.请问如何将我的店铺标注在百度地图上?我是否可以做区域代理?在百度地图上标注是否免费? 答复: 这里只负责API的技术咨询,不解决任何地图标注问题.在百度地图上标注自己公司,即气泡标注业务.该业务已 ...

  8. 【百度地图API】如何进行地址解析与反地址解析?——模糊地址能搜索到精确地理信息!

    原文:[百度地图API]如何进行地址解析与反地址解析?--模糊地址能搜索到精确地理信息! 摘要: 什么是地址解析? 什么是反地址解析? 如何运用地址解析,和反地址解析? 可以同时运用地址解析,和反地址 ...

  9. 关于 WebBrowser调用百度地图API 鼠标滚轮缩放地图级别失灵的解决办法

    在桌面程序下 百度地图API的鼠标缩放地图功能可能会失灵无效! 这个原因不是API的问题 小弟试了下在WEB上面是没有问题的 于是考虑可能是WebBrowser的获取焦点问题,于是在主窗体 添加了一个 ...

随机推荐

  1. css-css权威指南学习笔记4

    第三章 1.继承的值没有特殊性,甚至连0的特殊性都没有.所以改变超链接的样式一般需要独立声明,无法通过继承改变. 2.层叠--冲突的声明通过这个层叠的过程排序,并由此确定最终的文档表示.这个过程的核心 ...

  2. COGS14. [网络流24题] 搭配飞行员

    [问题描述]     飞行大队有若干个来自各地的驾驶员,专门驾驶一种型号的飞机,这种飞机每架有两个驾驶员,需一个正驾驶员和一个副驾驶员.由于种种原因,例如相互配合的问题,有些驾驶员不能在同一架飞机上飞 ...

  3. python标准模块(三)

    本文会涉及到的模块: subprocess logging 1. subprocess 可以执行shell命令的相关模块和函数有: os.system os.spawn os.popen --废弃 p ...

  4. springmvc @PathVariable("b") double b 丢失精度问题

    Spring MVC从3.0开始支持REST,而主要就是通过@PathVariable来处理请求参数和路径的映射.由于考虑到SEO的缘故,很多人喜欢把新闻的名称作为路径中的一部分去处理,这时候中文的名 ...

  5. 面试题目——《CC150》链表

    面试题2.1:编写代码,移除未排序链表中的重复结点 进阶:如果不得使用临时缓冲区,该怎么解决? package cc150; import java.util.HashMap; import java ...

  6. Node.js入门笔记(3):全局对象(2)

    buffer 用于更好操作二进制数据,他是一个全局变量.类似数组. var a=new Buffer(); buffer类的三种实现 第一种创建方式 new Buffer(size);size[Num ...

  7. Java实现Excel的操作

    JAVA EXCEL API: 开源项目,通过它Java开发人员可以读取Excel文件的内容.创建新的Excel文件.更新已经存在的Excel文件.使用该API非Windows操作系统也可以通过纯Ja ...

  8. Asp.Net Core--自定义基于策略的授权

    翻译如下: 在封面下,角色授权和声明授权使用需求,需求的处理程序和预配置的策略. 这些构建块允许您在代码中表示授权评估,从而允许更丰富,可重用和容易测试的授权结构. 授权策略由一个或多个需求组成,并在 ...

  9. C++ 异常机制

    程序在运行的时候可能产生各种可预料到的异常,例如磁盘不足,内存不足,或是数学运算溢出,数组越界之类的.为了解决这些问题,C++提供了异常处理机制,它一般是由try语句和catch语句构成. 一.try ...

  10. word20161213

    journal queue / 日志队列 journal quota / 日志配额 junction point / 交叉点 KDC, Key Distribution Center / 密钥分发中心 ...