java提取字符串中汉字、数字、字母

import java.util.regex.*;
//匹配汉字、字符串、数字
public class Test9 
{
	public static void main(String[] args) 
	{
		String regEx1 = "[\\u4e00-\\u9fa5]";
		String regEx2 = "[a-z||A-Z]";
		String regEx3 = "[0-9]";
		String str = "1 2fdAsz我是hhhZ大傻逼";
		String s1 = matchResult(Pattern.compile(regEx1),str);
		String s2 = matchResult(Pattern.compile(regEx2),str);
		String s3 = matchResult(Pattern.compile(regEx3),str);
		System.out.println(s1+"\n"+s2+"\n"+s3);
	} 
	
	public static String matchResult(Pattern p,String str)
	{
		StringBuilder sb = new StringBuilder();
		Matcher m = p.matcher(str);
		while (m.find())
		for (int i = 0; i <= m.groupCount(); i++) 
		{
			sb.append(m.group());   
		}
		return sb.toString();
	}
}

### 回答1: 可以使用正则表达式来实现。 代码示例: ``` String str = "Hello, 世界! 123"; String chinese = str.replaceAll("[^\u4e00-\u9fa5]", ""); // 提取中文汉字 String special = str.replaceAll("[a-zA-Z0-9\u4e00-\u9fa5\\s]", ""); // 提取特殊字符,忽略数字 ``` 上面的代码,chinese变量存储的是提取出来的中文汉字,special变量存储的是提取出来的特殊字符。 另外,"[^\u4e00-\u9fa5]" 正则表达式表示的是所有不在这个范围内的字符, "[a-zA-Z0-9\u4e00-\u9fa5\\s]" 正则表达式表示的是所有在这个范围内的字符 ### 回答2: 要提取字符串汉字和特殊字符,而忽略数字,可以使用Java正则表达式。 首先,我们可以使用正则表达式"[\u4e00-\u9fa5\\p{P}]",其"\u4e00-\u9fa5"代表汉字的Unicode编码范围,"\\p{P}"代表所有的标点符号和特殊字符。这个正则表达式可以用来匹配汉字和特殊字符。 我们可以通过以下步骤来实现提取汉字和特殊字符: 1. 创建一个Pattern对象,使用上述正则表达式作为参数。 2. 创建一个Matcher对象,使用要提取字符串作为参数,并调用matcher()方法。 3. 使用find()方法来查找下一个匹配项。 4. 如果找到了匹配项,可以通过调用group()方法来获取匹配到的字符串。 5. 判断字符串是否为数字,如果不是数字,则将其保存到一个结果字符串。 6. 重复步骤3到5,直到找不到匹配项为止。 以下是一个示例代码: ```java import java.util.regex.Matcher; import java.util.regex.Pattern; public class Main { public static void main(String[] args) { String str = "abc123汉字,!@#"; String result = ""; Pattern pattern = Pattern.compile("[\u4e00-\u9fa5\\p{P}]"); Matcher matcher = pattern.matcher(str); while (matcher.find()) { String match = matcher.group(); if (!match.matches("\\d+")) { result += match; } } System.out.println(result); } } ``` 在上述示例,输入的字符串是"abc123汉字,!@#",输出结果是"汉字,!@#",其数字"123"被忽略掉了。 ### 回答3: 在Java提取字符串汉字和特殊字符并忽略数字,可以使用正则表达式进行匹配。以下是一种实现方法: 首先,使用正则表达式`[^\u4E00-\u9FA5a-zA-Z0-9]`匹配字符串的非汉字、非字母、非数字的特殊字符。其,`\u4E00-\u9FA5`表示汉字的Unicode范围。通过使用`[^...]`来匹配除括号内字符之外的任意字符。 接着,使用`replaceAll()`方法将匹配到的特殊字符替换为空格,从而实现忽略这些特殊字符。 最后,使用正则表达式`[^\\p{P}\u4E00-\u9FA5]+`匹配除了汉字和标点符号之外的任意字符,再次使用`replaceAll()`将这些字符替换为空格。 下面是具体的实现代码: ```java public class Main { public static void main(String[] args) { String str = "abc你好123!@#$%哈哈123"; String regex = "[^\\u4E00-\\u9FA5a-zA-Z0-9]"; String result = str.replaceAll(regex, ""); regex = "[^\\p{P}\\u4E00-\\u9FA5]+"; result = result.replaceAll(regex, ""); System.out.println(result); } } ``` 运行上述代码,输出结果为`abc你好哈哈`。即成功提取字符串汉字和特殊字符,忽略了数字
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值