怎么用SQL或者PYTHON批量生成11位手机号码?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了怎么用SQL或者PYTHON批量生成11位手机号码?相关的知识,希望对你有一定的参考价值。

怎么用SQL或者PYTHON批量生成11位手机号码?前边固定7位数(例如1381212)只生成后4位,比如1381212这个号段,最后生成1万个1381212****个号码。

python的话,可以定义一个迭代器:

def snx(prefix: str, width:int):

...."返回指定前缀+定长自增序号"

....idx=0

....fmt = ':0>'.format(prefix,width)

....while idx < 10 ** width:

........yield fmt.format(idx)

........idx = idx + 1

sn4 = snx('1381212', 4)

print(next(sn4))  # 13812120000

print(next(sn4))  # 13812120001

如果不考虑通用性的话,直接就用列表表达式也成:

phone_numbers = ['1381212:0>4'.format(i) for i in range(10000)]


SQL的话,没有迭代器,也没有这么好用的字符串格式化,只能麻烦一点了:

declare @idx int = 0

while @idx < 10000

begin

    print('1381212' + right(replicate('0',4) + convert(varchar(4), @idx), 4))

    select @idx = @idx + 1

end

参考技术A for i in range(1000):
print(f'1381212str(i).rjust(4, "0")')

# 13812120000
# 13812120001
# 13812120002
# ...

Python之深入解析如何一键批量生成真实的手机号码及其号码归属地解析

① 目标场景

  • 平时在工作过程中,偶尔会需要大量的手机号码,去测试一些具体的业务功能,为了保证测试的有效性,手机号码的真实性尤为的重要。
  • 那如何按要求批量生成一些真实的手机号码呢?本文就带大家利用 Python 批量生成手机号码。

② 编写代码生成手机号码

  • 要批量生成手机号码,首先需要了解 11 位手机号码的组成规律,即:
    • 手机号码一共有 11 位,以 1 开头;
    • 第 2 位的数值是 3、4、5、7、8 中的一个;
    • 第 3 位根据第 2 位的数字,对应运营商的生成规律;
    • 后 8 位是随机生成的 8 个数字。
  • 知道手机号码的组成规律后,接着把数字拼接起来,即可以生成一个手机号码。
def create_a_phone():
    # 第二位数字
    second = [3, 4, 5, 7, 8][random.randint(0, 4)]

    # 第三位数字
    third = {3: random.randint(0, 9),
             4: [5, 7, 9][random.randint(0, 2)],
             5: [i for i in range(10) if i != 4][random.randint(0, 8)],
             7: [i for i in range(10) if i not in [4, 9]][random.randint(0, 7)],
             8: random.randint(0, 9), }[second]

    # 最后八位数字
    suffix = random.randint(9999999, 100000000)

    # 拼接手机号
    return "1{}{}{}".format(second, third, suffix)
  • 由于三大运营商的号段一直在更新变化,上面组成的手机号码也有可能不是一个有效的号码。
  • 为了保证号码的真实性,利用号码去获取手机号码归属地,如果能获取到归属地,即代表为一个真实有效的号码。

  • 淘宝和百度都提供了查询归属地的 API,可以非常方便的查询号码的归属地:
def judge_phone_ava(phone):
    """
    判断手机号码是否合理
    :param phone:手机号码
    :return:
    """
    resp_content = requests.get('http://mobsec-dianhua.baidu.com/dianhua_api/open/location?tel=%s' % phone).content
    txt = json.loads(resp_content)

    result = txt.get('response').get(phone)

    return result
  • 循环上面的操作,可以生成一些随机的手机号码,正因为生成号码的随机性,使得数据的价值性大打折扣。

③ 生成指定城市的手机号码

  • 如果需要批量生成指定城市的手机号码,上面的这种方法没法做到。幸运地是,有一个网站已经实现了这个功能,只需要用 Python 模拟请求即可:

  • 选择手机号码归属地、包含号段、数量,就能快速生成想要的手机号码,按 F12 可以查看网络请求方式及参数:

  • 请求参数中的区域代码对应选择的省+市区,这部分数据利用 JS 加载到页面中:

  • 只需要解析网页源代码,利用正则表达式查找对应的字符串,解析出区域 ID 和城市名称:
def get_all_citys():
    """
    获取所有的城市数据
    :return:
    """

    headers = {
        'authority': 'uutool.cn',
        'pragma': 'no-cache',
        'cache-control': 'no-cache',
        'upgrade-insecure-requests': '1',
        'user-agent': 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/79.0.3945.88 Safari/537.36',
        'sec-fetch-user': '?1',
        'accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9',
        'sec-fetch-site': 'none',
        'sec-fetch-mode': 'navigate',
        'accept-encoding': 'gzip, deflate, br',
        'accept-language': 'zh-CN,zh;q=0.9,en;q=0.8',
        'cookie': 'UM_distinctid=16f759fe6bd24b-0322efd0d180d8-1d376b5b-1aeaa0-16f759fe6beb69; CNZZDATA1275106188=191793625-1578225029-https%253A%252F%252Fwww.google.com%252F%7C1578316721',
    }

    resp = requests.get('https://uutool.cn/phone-generate/', headers=headers).text

    re_rule = r'areaArr:(.+?)segmentArr:'

    # 匹配换行符
    result_data = re.findall(re_rule, resp, re.S)[0].strip()[:-1]

    result = json.loads(result_data)

    # 获取所有的省份
    provices = result.keys()

    # 所有的城市
    citys = {}

    for provice in provices:
        current_citys = result.get(provice)
        # citys.extend(current_citys)
        for item in current_citys:
            citys[item.get('name')] = item.get('id')

    return citys
  • 拿到城市名称和区域 ID 的关系数据后,模拟网络请求,即可以批量生成目标城市的手机号码:
citys = get_all_citys()

city_name = input('请输入手机归属地:')

if city_name not in citys.keys():
     city_name = '北京'

# 获取城市id
city_id = citys.get(city_name)

phones = generate_phones(num, city_id)

# pass

④ 结论

  • 通过上面的操作,就能按照自己的需求,批量生成一些真实有效的手机号码。
  • 接下来,可以结合自动化操作,可以使得我们生成的数据价值最大化。

以上是关于怎么用SQL或者PYTHON批量生成11位手机号码?的主要内容,如果未能解决你的问题,请参考以下文章

Python之深入解析如何一键批量生成真实的手机号码及其号码归属地解析

sql 批量修改数据

python脚本批量生成数据

Java 批量随机生成身份证号码

python怎么把图片生成二维码?

python3 测试的时候如何批量随机生成伪数据?(faker模块的)