J023_用正则表达式爬取信息

一、需求描述

请把下面文本中的电话、邮箱、座机号码和热线都爬取出来:

来黑马程序员学习Java,电话:18512566758,18354678765;或者联系邮箱:boniu@itcast.cn;座机电话:010365178955,010-989512356;邮箱bozai@itcast.cn,邮箱2:diei0009@163.com;热线电话:400-618-9090,400-618-4000,4006184000,4006180909。

二、代码实现

java 复制代码
package com.itheima.regex;

import java.util.regex.Matcher;
import java.util.regex.Pattern;

public class TestCase2 {
    public static void main(String[] args) {
        method1();
    }

    public static void method1(){
        //文本
        String data = "来黑马程序员学习Java,\n" +
                "      电话:18512566758,18354678765;\n" +
                "      或者联系邮箱:boniu@itcast.cn;\n" +
                "      座机电话:010365178955,010-989512356;\n" +
                "      邮箱bozai@itcast.cn,\n" +
                "      邮箱2:diei0009@163.com;\n" +
                "      热线电话:400-618-9090,400-618-4000,4006184000,4006180909。";

        //定义爬取规则
        String regex = "(1[3-9]\\d{9})|(0\\d{2,7}-?[1-9]\\d{4,19})|\\w{2,}@\\w{2,20}(\\.\\w{2,10}){1,2}" +
                       "|(400-?\\d{3,7}-?\\d{3,7})";

        //把正则表达式封装成一个pattern对象
        Pattern pattern = Pattern.compile(regex);

        //通过pattern对象去获取查找内容的匹配器对象
        Matcher matcher = pattern.matcher(data);

        //定义循环开始爬取信息
        while (matcher.find()) {
            String result = matcher.group();
            System.out.println(result);
        }
    }
}
相关推荐
二月夜1 小时前
剖析Java正则表达式回溯问题
java·正则表达式
xuhaoyu_cpp_java1 小时前
项目学习(三)分页查询
java·经验分享·笔记·学习
程序员二叉2 小时前
【Java】集合面试全套精讲|HashMap/ArrayList高频考点完整版
java·面试·哈希算法
cfm_29142 小时前
JVM GC垃圾回收初步了解
java·开发语言·jvm
心之伊始2 小时前
LangChain4j RAG 实战:Java 后端如何把本地文档接入 Embedding 检索链路
java·架构·源码分析·csdn
许彰午3 小时前
17_synchronized关键字深度解析
java·开发语言
Xzh04234 小时前
AI Agent 学习路线(Java 后端方向)
java·人工智能·学习
艾利克斯冰5 小时前
Java 设计模式-行为型模式(更新中)
java·开发语言·设计模式
倒霉蛋小马5 小时前
Java新特性:record关键字
java·开发语言
折哥的程序人生 · 物流技术专研5 小时前
《Java 100 天进阶之路》第95篇:消息队列基础(RocketMQ/Kafka)(2026版)
java·面试·kafka·rocketmq·java-rocketmq·求职招聘