C#如何提取經緯度文件中的經緯度數據

前言:

之前我們使用對List將數據封裝進KML經緯度文件中,今天我們來學習一下如何將經緯度文件中的經緯度數據讀出來,並保存在變量中,這個變量可以是list也可以是數組,隻要能儲存數據就可以,我們對KML文件中的Point數據下面的coordinates數據讀出來即可!!!

一、界面設計

設計瞭兩個選項,可以選擇不同的效果進行提取經緯度數據,第一代表可以把數據提取到TXT文本文件中,而第二表示不會生成TXT文件隻在文本框中展示你的提取數據,可以看後面的代碼邏輯,有一個函數是專門負責數據的提取,是使用XML讀取的形式讀取指定的標簽數據

二、效果展示

目前隻展示瞭不會導出TXT文件的效果,隻是對數據展示在文本框中。你們也可以按照自己的需求接著寫接著添加自己想要的功能,後面有代碼邏輯,代碼也有註解,不至於不能懂,有啥問題評論區評論

三、代碼邏輯

使用的是XML文件讀取的形式,利用XML的節點的方式,對數據的標簽遍歷得到,對應的標簽,再對指定的coordinates標簽的數據進行提取並賦值,從而實現提取KML文件中的經緯度的數據效果。

//自定義類的函數
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using System.Xml;
​
namespace FileConversion
{
    public class DataExtract
    {
        /// <summary>
        /// 對指定路徑的kml文件,經緯度讀取,並返回經緯度集合MapConfig
        /// </summary>
        /// <param name="Path">文件路徑名</param>
        /// <returns></returns>
        public List<String> MapConfigs(string filename)
        {
            List<String> mapConfigs = new List<String>();//實例化list集合
           
            string destPath = filename;//賦值文件路徑
            if (destPath == null)//判斷路徑是否為空
            {
                MessageBox.Show("路徑為空");
                return null;
            }   
            XmlDocument xmldoc = new XmlDocument();
            try
            {
                xmldoc.Load(destPath);//加載kml文件
                XmlElement root = xmldoc.DocumentElement;
                XmlNodeList xmlmark = root.GetElementsByTagName("coordinates");//獲取coordinates節點
                int i = 0;
                foreach (XmlNode xmlmarkNode in xmlmark)//遍歷所有coordinates節點
                {
                    if (xmlmarkNode.Name == "coordinates")
                    {
                        i++;
                        string mapConfig = "";//實例化
                        string str = xmlmarkNode.InnerText;//獲取節點的值
                        if (str.Equals("") || str.Contains(",") == false)
                        {
                            MessageBox.Show("第"+i.ToString()+"行數據有誤,將返回NULL值","錯誤");
                            return null;
                        }
                        string[] strings = str.Split(',');//對節點的值字符串進行分割
                        mapConfig+= strings[0]+",";//經度值
                        mapConfig+= strings[1]+",";//緯度值
                        mapConfig+= strings[2];//
                        mapConfigs.Add(mapConfig);//添加在list中
                    }
                }
                return mapConfigs;
            }
            catch
            {
                MessageBox.Show("文件加載失敗或coordinates節點數據獲取失敗", "錯誤");
                return null;//註:kml文件如果使用wps或者word打開會再運行本程序會報錯,文本打開運行不會報錯
            }
            
        }
    }
}
​
​
//上面是我們需要調用的類
​​
//這個是我們界面設計調用的類
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.IO;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
​
namespace FileConversion
{
    public partial class Form4 : Form
    {
        public Form4()
        {
            InitializeComponent();
        }
        public string KmlPath = "";
        private void button6_Click(object sender, EventArgs e)
        {
            OpenFileDialog openFile = new OpenFileDialog();
            openFile.Filter = "KML文件(*.kml)|*.kml|所有文件|*.*";
            if (openFile.ShowDialog() != DialogResult.OK)//打開文件是否點擊瞭取消
                return;
            KmlPath = openFile.FileName;
            textBox1.Text = KmlPath;
        }
​
        private void button7_Click(object sender, EventArgs e)
        {
            DataExtract data = new DataExtract();//自定義的函數,復制kml文件經緯度數據提取
            if (KmlPath.Equals("") == true)
            {
                MessageBox.Show("選擇文件之後才能導出");
            }
            else
            {
                if (checkBox1.Checked == true && checkBox2.Checked == false || checkBox1.Checked == true && checkBox2.Checked == true)
                {
                    List<string> list = data.MapConfigs(KmlPath);
                    string localFilePath = "";//文件路徑
                    SaveFileDialog save = new SaveFileDialog();
                    save.Filter = "Txt(*.txt)|*.txt";        //設置文件類型  
                    save.RestoreDirectory = true; //保存對話框是否記憶上次打開的目錄 
                    if (save.ShowDialog() == DialogResult.OK)//點瞭保存按鈕進入 
                    {
                        localFilePath = save.FileName.ToString(); //獲得文件路徑 
                        string fileName = localFilePath.Substring(localFilePath.LastIndexOf("\") + 1); //獲取文件名,不帶路徑
                        //FileStream file = new FileStream(localFilePath, FileMode.Create);
                        foreach (string kml in list)
                        {
                            textBox2.Text += kml + "\r\n";
                            File.AppendAllText(localFilePath, kml + "\r\n");
                        }
​
                    }
                }
                else if (checkBox1.Checked == false && checkBox2.Checked == true)
                {
                    List<string> list = data.MapConfigs(KmlPath);
                    foreach (string kml in list)
                    {
                        textBox2.Text += kml + "\r\n";
                    }
                }
                else
                {
                    MessageBox.Show("選擇你需要的項");
                }
            }
        }
    }
}

總結:

這篇文章比較簡單,裡面也已經寫好瞭方法讓我們調用就可以瞭,界面制作比較簡單,但是是一個比較實用的一個小工具。

到此這篇關於C#如何提取經緯度文件中經緯度數據的文章就介紹到這瞭,更多相關C#提取經緯度數據內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: