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);
        }
    }
}
相关推荐
smileNicky10 分钟前
Lombok @Data 在 IDEA 中运行报错解决方案
java·ide·intellij-idea
计算机学姐10 分钟前
基于SpringBoot的汉服租赁系统【颜色尺码套装+个性化推荐算法+数据可视化统计】
java·vue.js·spring boot·后端·mysql·信息可视化·推荐算法
qq_54702617912 分钟前
Maven 仓库管理
java·maven
天天摸鱼的java工程师15 分钟前
线程池深度解析:核心参数 + 拒绝策略 + 动态调整实战
java·后端
mjhcsp15 分钟前
C++ KMP 算法:原理、实现与应用全解析
java·c++·算法·kmp
邵伯22 分钟前
Java源码中的排序算法(一)--Arrays.sort()
java·排序算法
阿里巴巴P8高级架构师28 分钟前
从0到1:用 Spring Boot 4 + Java 21 打造一个智能AI面试官平台
java·后端
stevenzqzq30 分钟前
trace和Get thread dump的区别
java·android studio·断点
桦说编程31 分钟前
并发编程踩坑实录:这些原则,帮你少走80%的弯路
java·后端·性能优化
程序猿零零漆32 分钟前
Spring之旅 - 记录学习 Spring 框架的过程和经验(十三)SpringMVC快速入门、请求处理
java·学习·spring