文章目录

  • 一、使用场景
    • 二、问题描述
      • 三、解决方案
        • 四、方法补充
        • 方法一:
          • 方法二

一、使用场景

对手机号码进行地域分析,需要查询归属地;

二、问题描述

针对数据集比较大的情况,通过脚本来处理,使用多线程的方法来加快查询速度

pool = multiprocessing.Pool(processes=pool_count)for i in data_cut(data,pool_count):data_log_list.append(pool.apply_async(main, (i,)))pool.close()pool.join()

三、解决方案

创建一个 pool 进程池,然后通过data_cut将数据读取并且等分成数据组,设置好pool_count进程数量就可以开始,每个数据组独立查询然后将结果汇总给push_log进行最终处理,保存为csv文件。

# 电话号码归属地查询import os
import sys
import time
import json
import warnings
import pandas as pd
import multiprocessing
from phone import Phone
warnings.filterwarnings("ignore")
path = os.path.abspath(".")def data_cut(data_list,data_cut=4):#将任务拆分,建议拆分数为CPU核心数,默认为4#分组数据,分组间隔data_all=[]if data_cut > len(data_list):data_cut = len(data_list)data_cut_num = int((len(data_list)+1)/data_cut)for i in range(1,data_cut+1):if i < data_cut:data_1=data_list[data_cut_num*(i-1):data_cut_num*i]else:data_1=data_list[data_cut_num*(i-1):]data_all.append(data_1)return data_alldef push_log(data_log_list,file_name):data_all = []data_list = [i.get() for i in data_log_list]for i in data_list:for j in i:data_all.append(j)data_all = pd.DataFrame(data_all)data_all.to_csv(path + "/phone_{}.csv".format(file_name),index=False,encoding='gbk')print('成功查询:',data_all.shape[0])def main(data):resp = []for i in data:try:if type(Phone().find(i)) == dict:resp.append(Phone().find(i))except:passreturn respif __name__ == '__main__':start_time= time.time()file_name = name = sys.argv[1]data = pd.read_table(path + "/{}".format(file_name),header=None)data=list(data[0])pool_count = 12data_log_list = []pool = multiprocessing.Pool(processes=pool_count)for i in data_cut(data,pool_count):data_log_list.append(pool.apply_async(main, (i,)))pool.close()pool.join()push_log(data_log_list,file_name)print(time.time()-start_time)

四、方法补充

除了上文的方法,小编还为大家整理了一些其他Python号码归属地查询的方法,需要的可以参考一下

方法一:

import requestsdef get_callerloc(phone):url = f"https://www.qvdv.com/tools/qvdv-api-mobile.html?f=json&mobile={phone}"headers = {'user-agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/100.0.4896.75 Safari/537.36',}response = requests.request("GET", url, headers=headers).json()return response["message"]if __name__ == '__main__':phone = input("请输入手机号(查询归属地):")res = get_callerloc(phone)print("手机号码:"+res["mobile"])print("归属地:"+res["province"])print("运营商:"+res["supplier"])

截图

方法二

GUI

from tkinter import *
from tkinter import ttk
from tkinter import messagebox
from Get_Attr import Get_Infos
import re
import threading
class App:
def __init__(self):
self.root=Tk()
self.root.title('手机号码归属地查询-v1.0')
self.root.resizable(0,0)
width=410
height=390
left=(self.root.winfo_screenwidth()-width)/2
top=(self.root.winfo_screenheight()-height)/2
self.root.geometry('%dx%d+%d+%d'%(width,height,left,top))
self.create_widet()
self.set_widget()
self.place_widget()
self.root.mainloop()
def create_widet(self):
self.l1=ttk.Label(self.root)
self.e1=ttk.Entry(self.root)
self.b1=ttk.Button(self.root)
self.lf=ttk.LabelFrame(self.root)
self.l2=ttk.Label(self.lf)
self.e2=ttk.Entry(self.lf)
self.l3=ttk.Label(self.lf)
self.e3=ttk.Entry(self.lf)
self.l4=ttk.Label(self.lf)
self.e4=ttk.Entry(self.lf)
self.l5=ttk.Label(self.lf)
self.e5=ttk.Entry(self.lf)
self.l6=ttk.Label(self.lf)
self.e6=ttk.Entry(self.lf)
self.l7=ttk.Label(self.lf)
self.e7=ttk.Entry(self.lf)
self.b1.config(command=lambda:self.thread_it(self.search_infos))
def set_widget(self):
self.e2_var=StringVar()
self.e3_var=StringVar()
self.e4_var=StringVar()
self.e5_var=StringVar()
self.e6_var=StringVar()
self.e7_var=StringVar()
self.l1.config(text='请输入手机号:')
self.b1.config(text='查询')
self.lf.config(text='查询结果')
self.l2.config(text='手机号码:')
self.l3.config(text='所属省份:')
self.l4.config(text='所属城市:')
self.l5.config(text='区   号:')
self.l6.config(text='邮   编:')
self.l7.config(text='类   型:')
#将字符串变量绑定Entry组件
self.e2.config(textvariable=self.e2_var)
self.e3.config(textvariable=self.e3_var)
self.e4.config(textvariable=self.e4_var)
self.e5.config(textvariable=self.e5_var)
self.e6.config(textvariable=self.e6_var)
self.e7.config(textvariable=self.e7_var)
self.root.bind('<Escape>',self.escape)
self.root.bind('<Return>',self.do_search)
def place_widget(self):
self.l1.place(x=30,y=20)
self.e1.place(x=130,y=20)
self.b1.place(x=290,y=20)
self.lf.place(x=30,y=60,width=350,height=300)
self.l2.place(x=60,y=10)
self.e2.place(x=150,y=10)
self.l3.place(x=60,y=50)
self.e3.place(x=150,y=50)
self.l4.place(x=60,y=90)
self.e4.place(x=150,y=90)
self.l5.place(x=60,y=130)
self.e5.place(x=150,y=130)
self.l6.place(x=60,y=170)
self.e6.place(x=150,y=170)
self.l7.place(x=60,y=210)
self.e7.place(x=150,y=210)
def search_infos(self):
pn=self.e1.get()
#判断输入类型,必须为11位数字
if re.match('\d{11}',pn):
result=Get_Infos().get_infos(pn)
self.e2_var.set(pn)
self.e3_var.set(result['province'])
self.e4_var.set(result['city'])
self.e5_var.set(result['areacode'])
self.e6_var.set(result['zip'])
self.e7_var.set(result['company'])
else:
messagebox.showwarning('警告','输入有误,请检查!')
#使用线程防止UI界面卡死
def thread_it(self,func,*args):
t=threading.Thread(target=func,args=args)
t.setDaemon(True)
t.start()
def escape(self,event):
self.root.destroy()
def do_search(self,event):
self.thread_it(self.search_infos())
if __name__ == '__main__':
a=App()

Get_Attr

import json
import requests
from urllib.parse import urlencode
class Get_Infos():
def __init__(self):
self.url='http://apis.juhe.cn/mobile/get?'
self.headers={'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/81.0.4044.138 Safari/537.36'
}
def get_infos(self,phone_num):
params={'phone':phone_num,
'key':'7a2b367a62fa24108b1f27ed4c84c97a',
'dtype':''
}
r=requests.get(self.url+urlencode(params),headers=self.headers)
_json=json.loads(r.text)
if _json.get('resultcode')=='200':
result=_json.get('result')
item={}
item['province']=result.get('province')
item['city']=result.get('city')
item['areacode']=result.get('areacode')
item['zip']=result.get('zip')
item['company']=result.get('company')
return item
else:
return False

Python实现手机号码归属地查询功能相关推荐

  1. HTML+JS 实现手机号码归属地查询功能

    手机号码归属地 API 是一种提供号码归属地信息的接口,它通过与运营商和电信数据库交互,根据手机号码查询相关归属地信息并返回结果.通过使用手机号码归属地API,开发者可以轻松地集成号码归属地查询功能到 ...

  2. Android:实现简单的手机号码归属地查询功能

    最近学习Android访问网络资源的相关知识,然后实现了一个简单的手机号码归属地功能,特此记录一下. 一.主界面Activity实现 主界面的编写很简单,只是添加了一个EditText用于输入电话号码 ...

  3. 基于python的手机号码归属信息查询系统

    import json import requests num = int(input('请输入你的手机号:')) url = 'http://apis.juhe.cn/mobile/get?phon ...

  4. python手机版代码-Python手机号码归属地查询代码

    简单的一个例子,是以前用Dephi写的,前不久刚实现了一个在Python中使用Delphi控件来编写界面程序,于是趁热写一个类似的的查询方案. 本实例是通过www.ip138.com这个网站来查询的, ...

  5. Android 简单几步实现手机号码归属地查询,可监听文本框的变化自动查询

    2019独角兽企业重金招聘Python工程师标准>>> 手机号码归属地查询需要用到一个数据库文件,我们可以用小米公司的数据库文件 第一步:数据库文件存储在 data/data/包名/ ...

  6. 调用聚合数据API实现手机号码归属地查询

    调用聚合数据API实现手机号码归属地查询 1.作者介绍 2.相关介绍 2.1 什么是聚合数据? 2.2 API介绍 2.3 手机号码归属地 3.实验过程 3.1如何调用聚合数据API 3.2代码实现 ...

  7. PHP+MYSQL实现手机号码归属地查询…

    手机号码归属地查询这个概念大家都不陌生吧!像我们在百度搜索框中输入一个正确的手机号码,点击搜索,就会显示这个手机号码的归属地和卡类型,非常方便.今天要为大家说的就是利用PHP+MYSQL的方法来实现手 ...

  8. java手机号归属地查询_【原创】Java实现手机号码归属地查询

    网络上已经有很多的手机号码归属地查询的API接口,但是这些接口总是有一些大大小小的缺陷. 总结一下这些缺陷: 1.要直接将它的搜索框链接形式粘到自己的页面,点击查询的时候还要跳转到他们的网站来展示归属 ...

  9. java 手机号码归属地_【原创】Java实现手机号码归属地查询

    网络上已经有很多的手机号码归属地查询的API接口,但是这些接口总是有一些大大小小的缺陷. 总结一下这些缺陷: 1.要直接将它的搜索框链接形式粘到自己的页面,点击查询的时候还要跳转到他们的网站来展示归属 ...

最新文章

  1. mysql年月分表_MySQL之按月拆分主表并按月分表写入数据提高数据查询速度
  2. SQL Server 2008 :安装
  3. 警方办案滥用谷歌地理围栏,小伙三次骑车路过案发点被视作嫌犯
  4. python数据结构视频百度云盘_数据结构与算法Python视频领课
  5. 详解python中的round()函数
  6. oracle 创建表空间 pcincrease,oracle建表空间 各种语句
  7. Jmeter使用笔记之意料之外的
  8. redis订阅执行一段时间自动停止_面试系列 redis 分布式锁amp;数据一致性
  9. [JavaWeb-MySQL]约束(非空约束,唯一约束,主键约束,外键约束_级联操作)
  10. nginx正向代理,反向代理概念
  11. 《Pro ASP.NET MVC 3 Framework》学习笔记之十八【URL和Routing】
  12. Vrep中支持的运动规划算法
  13. JMETER 为什么需要分布式
  14. 搞dedecms站 找后台的一些经验[转]
  15. xlsx文件打开乱码_我的 EXCEL 工作表打开出现乱码?(xlsx文件打开是乱码怎么办)...
  16. java移动文件导致tomcat死掉_利用平台自带的tomcat作为服务 当上传文件失败后服务总死掉...
  17. 10bit色深灰度图彩色图加载显示
  18. 无器械健身,是否真的比健身房器械训练要好?
  19. 台式计算机电源接线图,​台式机硬盘电源线接法【图解】
  20. 超说网络NO.4 | 深入了解应用层原理(中科大 郑烇)

热门文章

  1. 迅为IMX6ULL开发板搭建Web服务器(二)
  2. 电脑剪辑视频用什么工具?好用的视频剪辑工具推荐
  3. 智能优化算法——正余弦优化算法(SCA)及其改进策略
  4. python unicode码转换_python实现unicode转中文及转换默认编码的方法
  5. 病毒木马查杀实战第004篇:熊猫烧香之专杀工具的编写
  6. 软件测试基本价值观笔记
  7. 关于spring data jpa 仓储层自动实现
  8. CTF之懵懂时期系列---后台登录
  9. iPhone白苹果,刷机降级,无限重启,无限恢复模式,无限DFU模式,错误4013,错误3014...
  10. [Swift]LeetCode855. 考场就座 | Exam Room