Java常用API——String字符串运算
一、字符串运算 string类
1.概述
string是特殊的引用数据类型,它是final类。
2.构造方法
string str = "abc";
相当于: char date[] = {'a','b','c'};
string str = new string{data};
3.主要方法
char charat(int index) 返回char指定索引处的值。
boolean contains(charsequence s)当且仅当字符串包含指定char值序列返回true
boolean equals(object anobject) 将次字符串与指定对象进行比较
int indexof(int ch) 返回指定字符第一次出现的索引值
int length() 返回字符串的长度,多用于循环的终止条件
boolean matches(string regex) 判断一个字符串是否匹配给定的规则表达式
string replace(char oldchar,char newchar) 将串中所有的oldchar替换为newchar
string split(string regex) 将字符串按照规矩进行切分
string substring(int beginindex) 返回该字符串的beginindex索引之后的字符串
string tolowercase() 将该字符串中的所有大写字母变为小写字母
string touppercase() 将该字符串中的所有小写字母变为大写字母
string trim() 删除该字符串所有前导和尾随的空格并返回
/*类型转换*/
static string valueof(boolean b)
返回 boolean参数的字符串 boolean形式。
static string valueof(char c)
返回 char参数的字符串 char形式。
static string valueof(char[] data)
返回 char数组参数的字符串 char形式。
static string valueof(char[] data, int offset, int count)
返回 char数组参数的特定子阵列的字符串 char形式。
static string valueof(double d)
返回 double参数的字符串 double形式。
static string valueof(float f)
返回 float参数的字符串 float形式。
static string valueof(int i)
返回 int参数的字符串 int形式。
static string valueof(long l)
返回 long参数的字符串 long形式。
static string valueof(object obj)
返回 object参数的字符串 object形式。
注意:string字符串“==”与equals方法的区别:
如果是通过string str = ""声明的,==和equals都可是使用;
如果是通过new string ("")声明的,不能用==,只能用equals。
4.演示案例
需求一:计算一个字符串中大写字母、小写字母和数字的个数
思路:将字符串通过for循环进行便利,使用charat方法获取每一位字符,然后将每一位字符与ascii码对应的值相对比判断是大写字母、小写字母、数字,计数打印。
/**
* @ author: princesshug
* @ date: 2019/2/7, 17:09
* @ blog: https://www.cnblogs.com/hellobigtable/
*/
public class stringapidemo {
/**
* 需求:计算字符串中大写字母、小写字母、数字出现的次数
* @param args 参数
*/
public static void main(string[] args) {
//通过用户输入得到一个字符串
string str = getstring();
getcount(str);
}
private static void getcount(string str) {
int uppernum = 0;
int lowernum = 0;
int digit = 0;
for (int i = 0;i< str.length();i++){
char c = str.charat(i);
/**
* ascii码数字1-9(48-57),a-z(65-91),a-z(97-123)
*/
if (c>=48 && c<=57){
digit++;
}
if (c>=65 && c<=91){
uppernum++;
}
if (c>=97 && c<=123){
lowernum++;
}
}
system.out.println("数字出现的次数为:" + digit);
system.out.println("大写字母出现的次数为:" + uppernum);
system.out.println("小写字母出现的次数为:" + lowernum);
}
private static string getstring() {
system.out.println("请输入一个字符串:");
scanner scanner = new scanner(system.in);
string s = scanner.nextline();
return s;
}
}
需求二:查询父字符串中某一个子字符串出现的次数
思路1:使用indexof方法查询子字符串第一次出现的索引a,再使用substring方法返回父字符串索引(a+子字符串长度)之后的字符串,并计数+1,循环该操作知道indexof方法返回值为-1停止,获取计数值即可。
思路2:使用split方法将父字符串按照子字符串进行切分得到string数组,使用substring方法获取父字符串最后的字符串是否等于子字符串,若等于,返回string数组的length长度;若不等,则返回string数组的length-1.
**
* @ author: princesshug
* @ date: 2019/2/7, 17:34
* @ blog: https://www.cnblogs.com/hellobigtable/
*/
public class findchildstringcount {
/**
* 需求:查询父字符串中某一个子字符串的数量
* @param args
*/
public static void main(string[] args) {
string parent = "itstar123qweritstar()%%dfitstarsdgji";
string child = "itstar";
int num1 = getchildstringcount01(parent, child);
int num2 = getchildstringcount02(parent,child);
int num3 = getchildstringcount03(parent,child);
system.out.println("方法一:" + num1 + "次。");
system.out.println("方法二:" + num2 + "次。");
system.out.println("方法三:" + num3 + "次。");
}
private static int getchildstringcount02(string parent, string child) {
string[] s = parent.split(child);
if (child.equals(parent.substring(parent.length()-child.length()))){
return s.length;
}else {
return s.length-1;
}
}
private static int getchildstringcount01(string parent,string child) {
int num = 0;
int index = 0;
while ((index = parent.indexof(child)) != -1){
num++;
parent = parent.substring(index + child.length());
}
return num;
}
private static int getchildstringcount03(string parent,string child){
string[] s = parent.split(child);
int sum = 0;
for (int i = 0;i < s.length;i++){
sum += s[i].length();
}
return sum==parent.length()-(s.length-1)*child.length()?s.length-1:s.length;
}
}
5.string的规则匹配(正则表达式)
正则表达式常用于验证身份证号、qq号、邮箱等
字符类及含义:
[abc] => abc都可以
[a-za-z] => a-z或者a-z都可以,两头都是闭区间
[0-9] => 数字0-9都可以
\d => 与[0-9]一样
\d => 不能是数字
\w => 表示字母、数字、下划线都可以,等于[a-za-z0-9_]
x? => 表示x出现一次或一次也没有
x* => 表示x出现了零次或多次
x{n} => 表示x出现了n次
x{n,m} => 表示x出现了n到m次
x+ => 表示x至少出现了一次
^ => 表示正则表达式的开头
& => 表示正则表达式结尾
需求一:验证qq号码是否正确
qq号码条件:(1)位数为5-15位
(2)开头数字不能为0
正则表达式为:regex = [1-9]\\d{4-14}
需求二:验证手机号码是否正确
手机号条件:(1)位数为11位
(2)第一位为1
(3)第二位为3-9
正则表达式为:regex = [1]][3-9]\\d{9}
需求三:验证邮箱是否正确
邮箱条件:(1)@之前为邮箱名,字母、数字、下划线都可以
(2)@符号
(3)@之后为邮箱域名(qq.com/163.com.cn)
正则表达式为:regex = \\w+@[a-za-z0-9]+(\\.\\w{2,3})+
以下为需求一:验证qq号码是否正确,需求二、三只需将regex修改为对应的正则表达式即可。
/**
* @ author: princesshug
* @ date: 2019/2/7, 21:51
* @ blog: https://www.cnblogs.com/hellobigtable/
*/
public class matchqq {
public static void main(string[] args) {
while (true) {
string qq = getqq();
if (qq.equals("stop")){
break;
}else {
matchqq(qq);
}
}
}
/**
* @return 返回获取的qq号
*/
private static string getqq() {
scanner sc = new scanner(system.in);
system.out.println("请输入您的qq号");
string s = sc.nextline();
return s;
}
/**
* 验证qq号是否匹配regex表达式
* @param qq 获得用户输入的qq号
*/
private static void matchqq(string qq) {
string regex = qqregex();
if (qq.matches(regex)) {
system.out.println("qq号正确!");
} else {
system.out.println("qq号错误!");
}
}
/**
* @return 返回qq的正则表达式
*/
private static string qqregex() {
string regex = "[1-9][0-9]{4,14}";
return regex;
}
}