python-phonenumbers: 一个强大的电话号码处理库
2026-01-14 18:10:31作者:牧宁李
简介
python-phonenumbers 是一个用于验证、格式化、解析和提取电话号码的 Python 库。它支持超过 200 个国家和地区,并且可以轻松地处理各种复杂的电话号码格式。
功能与应用
验证
你可以使用 python-phonenumbers 来验证给定的电话号码是否有效。例如:
import phonenumbers
num = phonenumbers.parse("+14155552671", "US")
print(phonenumbers.is_valid_number(num)) # True
格式化
该库还提供了多种格式化选项,包括 E.164、国际格式、国家格式和本地格式等。下面是一个例子:
import phonenumbers
num = phonenumbers.parse("+14155552671", "US")
print(phonenumbers.format_number(num, phonenumbers.PhoneNumberFormat.E164)) # +14155552671
print(phonenumbers.format_number(num, phonenumbers.PhoneNumberFormat.INTERNATIONAL)) # +1 415-555-2671
print(phonenumbers.format_number(num, phonenumbers.PhoneNumberFormat.NATIONAL)) # (415) 555-2671
print(phonenumbers.format_number(num, phonenumbers.PhoneNumberFormat.LOCAL)) # 555-2671
解析
如果你有一个包含电话号码的字符串,但不确定它的格式或来源,可以使用 python-phonenumbers 的解析功能。它可以尝试猜测号码所在的区域代码并将其转换为一个 PhoneNumber 对象。
import phonenumbers
num_str = "(415) 555-2671"
parsed_num = phonenumbers.parse(num_str)
print(parsed_num.country_code) # 1
print(parsed_num.national_number) # 4155552671
提取
如果你需要从一段文本中提取出所有的电话号码,python-phonenumbers 提供了一个简单的 API 来实现这一点。
import phonenumbers
from phonenumbers import parser
text = "Call me at +14155552671 or 555-123-4567."
matches = phonenumbers.findall(text, "en-US")
for match in matches:
num = phonenumbers.parse(match.number, match.locale)
print(f"{match}: {num}")
以上是 python-phonenumbers 的一些基本功能和应用。无论你是要编写一个电话簿应用还是需要处理大量的电话号码数据,这个库都能派上用场。
特点
以下是 python-phonenumbers 的一些主要特点:
- 支持超过 200 个国家和地区的电话号码。
- 可以处理各种格式的电话号码。
- 提供了丰富的验证、格式化和解析功能。
- 基于 Google 开源的 libphonenumber 项目,具有很高的准确性和稳定性。
结语
如果你正在寻找一个强大而可靠的电话号码处理库,那么 python-phonenumbers 绝对值得你一试。现在就开始探索它吧!
登录后查看全文
热门项目推荐
相关项目推荐
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0228
cann-learning-hubCANN 学习中心仓,支持在线互动运行、边学边练,提供教程、示例与优化方案,一站式助力昇腾开发者快速上手。Jupyter Notebook0149
uni-appA cross-platform framework using Vue.jsJavaScript010
GLM-5.2智谱开源 GLM-5.2,这是针对长文本任务的最新旗舰模型。相较于前代产品 GLM-5.1,它在长文本任务处理能力上实现了显著飞跃,并且首次在稳定的 100 万 token 上下文中提供这一能力。Jinja00
SwanLab⚡️SwanLab - an open-source, modern-design AI training tracking and visualization tool. Supports Cloud / Self-hosted use. Integrated with PyTorch / Transformers / LLaMA Factory / veRL/ Swift / Ultralytics / MMEngine / Keras etc.Python00
tiny-universe《大模型白盒子构建指南》:一个全手搓的Tiny-UniverseJupyter Notebook04
项目优选
收起
暂无描述
Dockerfile
780
5.1 K
本项目是CANN提供的transformer类大模型算子库,实现网络在NPU上加速计算。
C++
890
2.05 K
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
471
471
本项目是CANN提供的神经网络类计算算子库,实现网络在NPU上加速计算。
C++
707
1.41 K
deepin linux kernel
C
32
16
Ascend Extension for PyTorch
Python
761
972
JiuwenSwarm 是一款基于openJiuwen开发的智能AI Agent,它能够将大语言模型的强大能力,通过你日常使用的各类通讯应用,直接延伸至你的指尖。
Python
2.27 K
679
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
1.11 K
1.15 K
本仓库是 Flutter SDK 与 Flutter Engine 的 OpenHarmony 适配版本,由 CPF-Flutter 团队维护。开发者可使用熟悉的 Flutter 技术栈开发 OpenHarmony 应用,3.35.7 及以后的适配版本可基于本仓库源码构建支持 OpenHarmony 的 Flutter Engine。
Dart
1.04 K
272
Claude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed.
Get Started
Rust
2.15 K
228