数据导入,手机号码归属地源码

这个博客介绍了一个Windows Forms应用程序,用于批量导入存储在多个TXT文件中的手机号码归属地数据。程序首先从用户选择的目录中读取所有TXT文件,然后清理数据库表中的原有数据,并将新数据插入到指定的数据库表中。每条记录包含开始号码、结束号码和运营商名称。此外,应用还提供了一个查询功能,可以根据输入的手机号码查询其归属地。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

using System;

using System.Collections.Generic;

using System.ComponentModel;

using System.Data;

using System.Drawing;

using System.Linq;

using System.Text;

using System.Windows.Forms;

using System.IO;

using System.Configuration;

using System.Data.SqlClient;

namespace 手机号码归属地

{

    public partial class Form1 : Form

    {

        public Form1()

        {

            InitializeComponent();

        }

        private void btn导入_Click(object sender, EventArgs e)

        {

            //创建文件选择窗口

            FolderBrowserDialog dlg = new FolderBrowserDialog();

            //如果没有选择文件就return

            if (dlg.ShowDialog() != DialogResult.OK)

            {

                return;

            }

            //获取选择的路径

            string path = dlg.SelectedPath;

            //清空原有数据

            string ConnStr = ConfigurationManager.ConnectionStrings["ConnStr"].ConnectionString;

            using (SqlConnection conn = new SqlConnection(ConnStr))

            {

                conn.Open();

                using (SqlCommand cmd = conn.CreateCommand())

                {

                    cmd.CommandText = "delete from T_Numbers";                    

                    cmd.ExecuteNonQuery();

                }

            }

            //读取path内的*.txt

            string[] files =  Directory.GetFiles(path, "*.txt"SearchOption.AllDirectories);

            using (SqlConnection conn = new SqlConnection(ConnStr))

            {

                conn.Open();

                using (SqlCommand cmd = conn.CreateCommand())

                {

                    cmd.CommandText = "insert into T_Numbers(startno,endno,name) values(@StartNo,@EndNo,@Name)";

                    foreach (string file in files)

                    {

                        string 运营商名称 = Path.GetFileNameWithoutExtension(file);

                        string[] lines = File.ReadAllLines(file, Encoding.Default);

                        foreach (string line in lines)

                        {

                            string[] strs = line.Split('-');

                            string 开始号码 = strs[0];

                            string 结束号码 = strs[1];

                            string 市 = strs[2];

                            cmd.Parameters.Clear();

                            cmd.Parameters.Add(new SqlParameter("StartNo", 开始号码));

                            cmd.Parameters.Add(new SqlParameter("EndNo", 结束号码));

                            cmd.Parameters.Add(new SqlParameter("Name", 市));

                            cmd.ExecuteNonQuery();

                        }

                    }

                }

            }

            MessageBox.Show("导入成功!");

        }

        private void button1_Click(object sender, EventArgs e)

        {

             string ConnStr = ConfigurationManager.ConnectionStrings["ConnStr"].ConnectionString;

             using (SqlConnection conn = new SqlConnection(ConnStr))

             {

                 conn.Open();

                 using (SqlCommand cmd = conn.CreateCommand())

                 {

                     cmd.CommandText = "select * from T_Numbers where StartNo<=@No and EndNo>=@No";

                     cmd.Parameters.Add(new SqlParameter("No", txtNo.Text));

                     using (SqlDataReader reader = cmd.ExecuteReader())

                     {

                         if (reader.Read())

                         {

                             string name = reader.GetString(reader.GetOrdinal("Name"));

                             MessageBox.Show("手机归属地:" + name);

                         }

                         else

                         {

                             MessageBox.Show("找不到运营商信息!");

                         }

                     }

                 }

             }

        }

    }

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值