java正则提取字符串中的符号汉字数字字母

提取字符串中的符号

	/**
	 * 提取字符串中的所有符号
	 * @param str
	 * @return
	 */
	public static String getSymbol (String str) {
        String chinese = "[\\u4e00-\\u9fa5\\w\\d]";//汉字字符集+英文字符集+数字字符集
        Pattern p = Pattern.compile(chinese);
        Matcher m = p.matcher(str);
        return m.replaceAll("");
    }
    public static void main(String[] args) throws Exception {
		String str = ".饿、啊,市。安·A 邯|山!z-吃123";
		str = getSymbol(str);
		System.out.println(str);
		//运行结果:.、,。· |!-
	}

提取字符串中的中文

//获取字符串中的中文
public static String getStrChinese(String str) {
	String regEx="[^\\u4e00-\\u9fa5]";
	Pattern p = Pattern.compile(regEx);
	Matcher m = p.matcher(str);
	return m.replaceAll("").trim();
}
public static void main(String[] args) {
	String str = ".饿、啊,市。安·A 邯|山!z-吃123";
	str = getStrChinese(str);
	System.out.println(str);
	//运行结果:饿啊市安邯山吃
}

提取字符串中的数字+英文

//获取字符串中的数字+英文
public  static String getStrNumberEnglish(String str) {
	String regEx="[^0-9A-Za-z]";
	Pattern p = Pattern.compile(regEx);
	Matcher m = p.matcher(str);
	return m.replaceAll("").trim();
}
public static void main(String[] args) {
	String str = ".饿、啊,市。安·A 邯|山!z-吃123";
	str = getStrNumberEnglish(str);
	System.out.println(str);
	//运行结果:Az123
}
### 回答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你好哈哈`。即成功提取字符串汉字和特殊字符,忽略了数字
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值