今天写程序的时候遇到一个问题,就是如果把一句话中的单词从这句话中分离出来
比如:Always bear in mind that your own resolution to success is more import than anything!
那么就把每个单词都分离开显示,以便进一步对分离的单词进行操作
实现起来很简单,即用到split方法和正则表达式的结合即可
import java.util.Scanner;
public class Test01 {
public static void main(String args[])
{
Scanner input=new Scanner(System.in);
String str = input.nextLine();
String[] arr=str.split("[^a-zA-Z0-9]+");
for(int i=0;i<arr.length;i++)
System.out.println(arr[i]);
System.out.println("There are "+arr.length+" words in the line!");
}
}
这样,就将里面的单词,分离出来了,如果有数字的话,也可以分离开来
下面就说说split方法的使用
一、split方法
java.lang.string.split
功能:将一个字符串分割成子字符串,然后将结果作为字符串数组返回
用法:stringObject.split([separator,[limit]])
split方法的结果是一个字符串数组,在stringObject中每个出现separator的位置都要进行分解
stringObject为必选项,就是要被分解的String对象或者文字,该对象不会被split方法修改
separator为可选项。字符串或者正则表达式对象,它标示了分离字符串时使用的是一个还是多个字符,如果忽略该选项
返回包含整个字符串的单一元素的数组。
limit可选项:这个值用来限制返回数组中元素个数
例子1:
public class Test01 {
public static void main(String args[])
{
String str = "what is your name";
String s[] = str.split(" ");
for(int i = 0; i < s.length; i++)
{
System.out.println(s[i]);
}
}
}
运行结果:
what
is
your
name
例子2:
public class Test01 {
public static void main(String args[])
{
String str = "what is your name";
String s[] = str.split(" ",3);
for(int i = 0; i < s.length; i++)
{
System.out.println(s[i]);
}
}
}
运行结果:
what
is
your name
例子3:
public class Test01 {
public static void main(String args[])
{
String str = "192.168.10.1";
String s[] = str.split("\\.");
for(int i = 0; i < s.length; i++)
{
System.out.println(s[i]);
}
}
}
运行结果:
192
168
10
1
这里会看到,split方法里多了两个斜杠,如果去掉斜杠后,运行,会发现,没有任何结果,其实split(String regex)方法中的regex是一个正则表达式,而.在正则表达式中有其他的意思,所以需要进行转义才可以用
下面的是从网上找到的
[size=12px]1。^\d+$ //匹配非负整数(正整数 + 0)
2。^[0-9]*[1-9][0-9]*$ //匹配正整数
3。^((-\d+)|(0+))$ //匹配非正整数(负整数 + 0)
4。^-[0-9]*[1-9][0-9]*$ //匹配负整数
5。^-?\d+$ //匹配整数
6。^\d+(\.\d+)?$ //匹配非负浮点数(正浮点数 + 0)
7。^(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*))$ //匹配正浮点数
8。^((-\d+(\.\d+)?)|(0+(\.0+)?))$ //匹配非正浮点数(负浮点数 + 0)
9。^(-(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*)))$ //匹配负浮点数
10。^(-?\d+)(\.\d+)?$ //匹配浮点数
11。^[A-Za-z]+$ //匹配由26个英文字母组成的字符串
12。^[A-Z]+$ //匹配由26个英文字母的大写组成的字符串
13。^[a-z]+$ //匹配由26个英文字母的小写组成的字符串
14。^[A-Za-z0-9]+$ //匹配由数字和26个英文字母组成的字符串
15。^\w+$ //匹配由数字、26个英文字母或者下划线组成的字符串
16。^[\w-]+(\.[\w-]+)*@[\w-]+(\.[\w-]+)+$ //匹配email地址
17。^[a-zA-z]+://匹配(\w+(-\w+)*)(\.(\w+(-\w+)*))*(\?\S*)?$ //匹配url
18。匹配中文字符的正则表达式: [\u4e00-\u9fa5]
19。匹配双字节字符(包括汉字在内):[^\x00-\xff]
20。应用:计算字符串的长度(一个双字节字符长度计2,ASCII字符计1)
String.prototype.len=function(){return this.replace([^\x00-\xff]/g,"aa").length;}
21。匹配空行的正则表达式:\n[\s| ]*\r
22。匹配HTML标记的正则表达式:/<(.*)>.*<\/\1>|<(.*) \/>/
23。匹配首尾空格的正则表达式:(^\s*)|(\s*$)
* 正则表达式用例
* 1、^\S+[a-z A-Z]$ 不能为空 不能有空格 只能是英文字母
* 2、\S{6,} 不能为空 六位以上
* 3、^\d+$ 不能有空格 不能非数字
* 4、(.*)(\.jpg|\.bmp)$ 只能是jpg和bmp格式
* 5、^\d{4}\-\d{1,2}-\d{1,2}$ 只能是2004-10-22格式
* 6、^0$ 至少选一项
* 7、^0{2,}$ 至少选两项
* 8、^[\s|\S]{20,}$ 不能为空 二十字以上
* 9、^\+?[a-z0-9](([-+.]|[_]+)?[a-z0-9]+)*@([a-z0-9]+(\.|\-))+[a-z]{2,6}$邮件
* 10、\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*([,;]\s*\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*)* 输入多个地址用逗号或空格分隔邮件
* 11、^(\([0-9]+\))?[0-9]{7,8}$电话号码7位或8位或前面有区号例如(022)87341628
* 12、^[a-z A-Z 0-9 _]+@[a-z A-Z 0-9 _]+(\.[a-z A-Z 0-9 _]+)+(\,[a-z A-Z 0-9 _]+@[a-z A-Z 0-9 _]+(\.[a-z A-Z 0-9 _]+)+)*$
* 只能是字母、数字、下划线;必须有@和.同时格式要规范 邮件
* 13 ^\w+@\w+(\.\w+)+(\,\w+@\w+(\.\w+)+)*$上面表达式也可以写成这样子,更精练。
14 ^\w+((-\w+)|(\.\w+))*\@\w+((\.|-)\w+)*\.\w+$ [/size]
- 大小: 8.5 KB
分享到:
相关推荐
输入一个字符串,从中依次取出连续的字母作为一个字母串,并将其首字母换成对应的大写字母,然后将取出的所有字母串输出。例如,输入字符串“we12are3*45Chinese.”输出的字母串依次为:We、Are和Chinese。
字符串单词提取 北大数算资源,需要的自己下载,我发福利啊
ES6--javascript判断一个字符串是否存在另一个字符串中
C语言编程-编写函数fun求一个字符串的长度,在main函数中输入字符串,并输出其长度;
在一个已知的字符串中查找最长单词,假定字符串中只含字母和空格,空格用来分隔不同单词。(C语言)
本文给出计算一个字符串中单词的个数的C语言程序,感性趣的朋友可以看看。
字符串分析,分别输出字符串中个单词,并统计出单词个数
计算字符串最后一个单词的长度,单词以空格隔开。 输入 一行字符串,长度小于128。 输出 整数N,最后一个单词的长度。 样例输入 hello world
292-用P0口显示字符串常量(51单片机C语言实例Proteus仿真和代码)292-用P0口显示字符串常量(51单片机C语言实例Proteus仿真和代码)292-用P0口显示字符串常量(51单片机C语言实例Proteus仿真和代码)292-用P0口显示字符串...
示例 1:输出:3解释:- "a" 是 "abc" 的子字符串。示例 3:输出:3解释:patterns 中的每个字符串都作为子字符串出现在 word "ab
本文实例讲述了C#判断字符串是否存在字母及字符串中字符的替换的方法。分享给大家供大家参考。具体实现方法如下: 首先要添加对命名空间“using System.Text.RegularExpressions;”的引用 下面以一个字符串为例: ...
HJ1-字符串最后一个单词的长度
434. 字符串中的单词数题目统计字符串中的单词个数,这里的单词指的是连续的不是空格的字符。输出: 5解释: 这里的单词是指连续的不是空格的字符,所以 "Hel
编译原理实验 c语言描述统计字符串中单词个数
动态规划算法:从1到26分别对应a-z的每一个字母,输入一串数字的字符串,转换为字母,输出所有可能的字母序列。如123->abc、lc、aw 本资源是按照二叉树的思想解决该问题。从字符串的头部开始,每次可以取一个或者两...
indexOf() 方法可返回某个指定的字符串值在字符串中首次出现的位置。如果要检索的字符串值没有出现,则该方法返回 -1。 方法二:match() var str = "123" var reg = RegExp(/3/); if(str.match(reg)){ //包含; } ...
关于经典算法--压缩字符串(将字符串内连续重复出现的字符进行压缩),个人的想法
、指定字符串分割字符串、指定字符串位置获取字符串、过滤SQL中非法字符、检查SQL语句中是否有非法关键字、随机字符串生成、唯一字符串生成、随机数字生成、唯一数字串生成、去除HTML标签、判断是否整型、判断是否...
c++使用vector统计字符串中单词出现的次数的方式,可以预先设置单词和句子,并给出句子中单词出现的次数
select f_find('Ap@2233ll@@l@@','@') from dual 返回结果为5,代表‘@’在该字符串中出现5次。 同理 select f_find('Ap@223SWEQQQ3ll@@l@@','Q') from dual---返回3,代表Q在字符串中出现了3次, select f_find('我...