一段关于正则表达式的例子

博客展示了Java代码中使用正则表达式处理字符串的过程。定义了不同的正则表达式用于提取地址和中文,通过Pattern和Matcher类进行匹配操作,最后将匹配结果替换并输出处理后的字符串,体现了正则表达式在字符串处理中的应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

String a = "<a href=/" http://www.dd.com/1.mp3/">http://wds.mp3</a>";
    String re = "< //s*a//s+href//s*=//s*/"|//s*/"//s*>|<(.[^>]*)>"; //取地址和中文
    String regex = "< //s*a//s+href//s*=//s*/"|//s*/"//s*>"; //取地址
    String reg = "<(.[^>]*)>"; //取中文
    Pattern p = Pattern.compile(re);
    Matcher math = p.matcher(a);
    StringBuffer bs = new StringBuffer();
    boolean b = math.find();
    while (b) {
      math.appendReplacement(bs, "");
      b = math.find();
    }
     math.appendTail(bs);
    System.out.println(bs);
### C++ 中正则表达式的示例代码 以下是基于标准库 `<regex>` 的 C++ 正则表达式示例代码: #### 示例 1:验证字符串是否匹配特定模式 此示例展示如何使用 `std::regex_match` 来判断整个字符串是否完全匹配给定的正则表达式。 ```cpp #include <iostream> #include <string> #include <regex> int main() { std::string text = "hello123"; std::regex pattern("^[a-z]+[0-9]+$"); // 字母开头,数字结尾 if (std::regex_match(text, pattern)) { std::cout << "The string matches the pattern." << std::endl; } else { std::cout << "The string does not match the pattern." << std::endl; } return 0; } ``` 上述代码定义了一个正则表达式 `^[a-z]+[0-9]+$`,用于匹配由字母组成并以数字结束的字符串[^1]。 --- #### 示例 2:查找子串中的所有匹配项 下面的例子展示了如何通过 `std::sregex_iterator` 查找目标字符串中所有的匹配部分。 ```cpp #include <iostream> #include <string> #include <regex> int main() { std::string text = "abc123 def456 ghi789"; std::regex pattern("[a-zA-Z]+"); auto words_begin = std::sregex_iterator(text.begin(), text.end(), pattern); auto words_end = std::sregex_iterator(); for (std::sregex_iterator i = words_begin; i != words_end; ++i) { std::smatch match = *i; std::cout << match.str() << std::endl; } return 0; } ``` 该程序利用迭代器提取输入字符串中的所有单词,并打印出来。 --- #### 示例 3:替换字符串中的指定模式 这个例子演示了如何用 `std::regex_replace` 替换掉符合某种模式的部分。 ```cpp #include <iostream> #include <string> #include <regex> int main() { std::string text = "Replace all numbers like 123 or 456 with 'XXX'."; std::regex pattern("\\d+"); std::string replacement = "XXX"; std::string result = std::regex_replace(text, pattern, replacement); std::cout << result << std::endl; return 0; } ``` 这里将所有连续的数字替换成 `"XXX"`。 --- ### 练习题目 以下是一些关于 C++ 正则表达式的练习题,帮助巩固所学知识: 1. **基础匹配** 编写一段代码来检测电子邮件地址的有效性。假设有效的邮箱格式为 `[username]@[domain].[extension]`,其中用户名可以包含字母、数字以及下划线 `_` 或连字符 `-`;域名至少有一个点分隔符 `.`, 并且扩展名长度不超过三个字符。 2. **分割字符串** 创建一个函数接受任意字符串作为参数,返回按逗号 `,` 分割后的向量容器(vector)。注意去除多余的空白字符。 3. **URL 提取** 设计一个算法从 HTML 文件内容里抽取所有的超链接 URL 地址。假定这些链接遵循这样的结构形式:`<a href="http://example.com">`. 4. **日志解析** 假设有一份服务器访问记录的日志文件每行形似这样:“`2023/10/01 12:34:56 GET /index.html HTTP/1.1 200`”。编写脚本统计不同状态码的数量分布情况。 5. **电话号码标准化** 实现功能把各种可能书写方式下的美国本土区号加七位数本地编号转换成统一的标准样式 `(xxx)-yyy-yyyy` 形态表示法。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值