python项目实战 查询手机号码归属地源码

get_mobile_from.py

python 复制代码
# 引入框架
import requests
from lxml import etree
from flask import Flask, render_template, request

# 创建一个app
app = Flask(__name__)


def get_phone_from(phone):
    # 发送请求的地址
    url = f"https://www.ip138.com/mobile.asp?mobile={phone}&action=mobile"

    # 直接请求会被网站屏蔽报错 需要伪装一下自己
    headers = {
        "User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/130.0.0.0 Safari/537.36 Edg/130.0.0.0"
    }

    # 发送请求
    resp = requests.get(url, headers=headers)

    # 设置字符集 中文显示
    resp.encoding = "utf-8"
    # 解析响应
    # print(resp.text)

    # 解析数据
    e = etree.HTML(resp.text)
    # xpath

    result = e.xpath("//tbody//tr//a[1]/text()")

    return result


# 主页
@app.route("/index")
def index():
    return render_template("/index.html")


# 定义路由地址
@app.route("/getPhoneFrom")
def getPhoneFrom():
    phone = request.args.get("phone")
    result = get_phone_from(phone)
    return render_template("index.html", result=result)


# 启动web服务
app.run(debug=True)

index.html

html 复制代码
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>

<body>
    <form action="/getPhoneFrom" method="get">
        手机号:<input type="text" name="phone" id="">
        <input type="submit" value="查询">
    </form>
    <table border="">
        <tr>
            <td>手机号:</td>
            <td>{{result[0]}}</td>

        </tr>
        <tr>
            <td>归属地:</td>
            <td>{{result[1]}}</td>
        </tr>
        <tr>
            <td>运营商:</td>
            <td>{{result[2]}}</td>
        </tr>
        <tr>
            <td>区号:</td>
            <td>{{result[3]}}</td>
        </tr>
        <tr>
            <td>邮编:</td>
            <td>{{result[4]}}</td>
        </tr>
    </table>
</body>

</html>
相关推荐
彭世瑜11 分钟前
ts: TypeScript跳过检查/忽略类型检查
前端·javascript·typescript
FØund40411 分钟前
antd form.setFieldsValue问题总结
前端·react.js·typescript·html
Backstroke fish12 分钟前
Token刷新机制
前端·javascript·vue.js·typescript·vue
zwjapple12 分钟前
typescript里面正则的使用
开发语言·javascript·正则表达式
小五Five13 分钟前
TypeScript项目中Axios的封装
开发语言·前端·javascript
小曲程序13 分钟前
vue3 封装request请求
java·前端·typescript·vue
临枫54114 分钟前
Nuxt3封装网络请求 useFetch & $fetch
前端·javascript·vue.js·typescript
前端每日三省15 分钟前
面试题-TS(八):什么是装饰器(decorators)?如何在 TypeScript 中使用它们?
开发语言·前端·javascript
小刺猬_98516 分钟前
(超详细)数组方法 ——— splice( )
前端·javascript·typescript
渊兮兮17 分钟前
Vue3 + TypeScript +动画,实现动态登陆页面
前端·javascript·css·typescript·动画