关于anindexof的信息

http://www.itjxue.com  2023-01-24 20:57  来源:未知  点击次数: 

java中字符、字符串的常用方法

char的所有方法:

static int charCount(int codePoint)

确定表示指定字符(Unicode 代码点)所需的 char 值的数量。

char charValue()

返回此 Character 对象的值。

static int codePointAt(char[] a, int index)

返回 char 数组的给定索引上的代码点。

static int codePointAt(char[] a, int index, int limit)

返回 char 数组的给定索引上的代码点,该数组中只有那些具有小于 limit 的 index 值的数组元素可以使用。

static int codePointAt(CharSequence seq, int index)

返回 CharSequence 的给定索引上的代码点。

static int codePointBefore(char[] a, int index)

返回 char 数组的给定索引前面的代码点。

static int codePointBefore(char[] a, int index, int start)

返回 char 数组的给定索引前面的代码点,该数组中只有那些具有大于等于 start 的 index 值的数组元素可以使用。

static int codePointBefore(CharSequence seq, int index)

返回 CharSequence 的给定索引前面的代码点。

static int codePointCount(char[] a, int offset, int count)

返回 char 数组参数的子数组中 Unicode 代码点的数量。

static int codePointCount(CharSequence seq, int beginIndex, int endIndex)

返回指定字符序列的文本范围内的 Unicode 代码点数量。

int compareTo(Character anotherCharacter)

根据数字比较两个 Character 对象。

static int digit(char ch, int radix)

返回使用指定基数的字符 ch 的数值。

static int digit(int codePoint, int radix)

返回使用指定基数的指定字符(Unicode 代码点)的数值。

boolean equals(Object obj)

将此对象与指定对象比较。

static char forDigit(int digit, int radix)

确定使用指定基数的特定数字的字符表示形式。

static byte getDirectionality(char ch)

返回给定字符的 Unicode 方向属性。

static byte getDirectionality(int codePoint)

返回给定字符(Unicode 代码点)的 Unicode 方向属性。

static int getNumericValue(char ch)

返回指定的 Unicode 字符表示的 int 值。

static int getNumericValue(int codePoint)

返回指定字符(Unicode 代码点)表示的 int 值。

static int getType(char ch)

返回一个指示字符的常规类别的值。

static int getType(int codePoint)

返回一个指示字符的常规类别的值。

int hashCode()

返回此 Character 的哈希码。

static boolean isDefined(char ch)

确定字符是否被定义为 Unicode 中的字符。

static boolean isDefined(int codePoint)

确定字符(Unicode 代码点)是否被定义为 Unicode 中的字符。

static boolean isDigit(char ch)

确定指定字符是否为数字。

static boolean isDigit(int codePoint)

确定指定字符(Unicode 代码点)是否为数字。

static boolean isHighSurrogate(char ch)

确定给出的 char 值是否为一个高代理项代码单元(也称为前导代理项代码单元)。

static boolean isIdentifierIgnorable(char ch)

确定是否应该认为指定字符是 Java 标识符或 Unicode 标识符中可忽略的一个字符。

static boolean isIdentifierIgnorable(int codePoint)

确定是否应该认为指定字符(Unicode 代码点)是 Java 标识符或 Unicode 标识符中可忽略的一个字符。

static boolean isISOControl(char ch)

确定指定字符是否为 ISO 控制字符。

static boolean isISOControl(int codePoint)

确定引用的字符(Unicode 代码点)是否为 ISO 控制字符。

static boolean isJavaIdentifierPart(char ch)

确定指定字符是否可以是 Java 标识符中首字符以外的部分。

static boolean isJavaIdentifierPart(int codePoint)

确定字符(Unicode 代码点)是否可以是 Java 标识符中首字符以外的部分。

static boolean isJavaIdentifierStart(char ch)

确定是否允许将指定字符作为 Java 标识符中的首字符。

static boolean isJavaIdentifierStart(int codePoint)

确定是否允许将字符(Unicode 代码点)作为 Java 标识符中的首字符。

static boolean isJavaLetter(char ch)

已过时。 由 isJavaIdentifierStart(char) 取代。

static boolean isJavaLetterOrDigit(char ch)

已过时。 由 isJavaIdentifierPart(char) 取代。

static boolean isLetter(char ch)

确定指定字符是否为字母。

static boolean isLetter(int codePoint)

确定指定字符(Unicode 代码点)是否为字母。

static boolean isLetterOrDigit(char ch)

确定指定字符是否为字母或数字。

static boolean isLetterOrDigit(int codePoint)

确定指定字符(Unicode 代码点)是否为字母或数字。

static boolean isLowerCase(char ch)

确定指定字符是否为小写字母。

static boolean isLowerCase(int codePoint)

确定指定字符(Unicode 代码点)是否为小写字母。

static boolean isLowSurrogate(char ch)

确定给定 char 值是否一个低代理项代码单元(也称为尾部代理项代码单元)。

static boolean isMirrored(char ch)

确定指定字符依据 Unicode 规范是否对称。

static boolean isMirrored(int codePoint)

确定指定字符(Unicode 代码点)依据 Unicode 规范是否对称。

static boolean isSpace(char ch)

已过时。 由 isWhitespace(char) 取代。

static boolean isSpaceChar(char ch)

确定指定字符是否为 Unicode 空白字符。

static boolean isSpaceChar(int codePoint)

确定指定字符(Unicode 代码点)是否为 Unicode 空白字符。

static boolean isSupplementaryCodePoint(int codePoint)

确定指定字符(Unicode 代码点)是否在增补字符范围内。

static boolean isSurrogatePair(char high, char low)

确定指定的 char 值对是否为有效的代理项对。

static boolean isTitleCase(char ch)

确定指定字符是否为首字母大写字符。

static boolean isTitleCase(int codePoint)

确定指定字符(Unicode 代码点)是否为首字母大写字符。

static boolean isUnicodeIdentifierPart(char ch)

确定指定字符是否可以是 Unicode 标识符中首字符以外的部分。

static boolean isUnicodeIdentifierPart(int codePoint)

确定指定字符(Unicode 代码点)是否可以是 Unicode 标识符中首字符以外的部分。

static boolean isUnicodeIdentifierStart(char ch)

确定是否允许将指定字符作为 Unicode 标识符中的首字符。

static boolean isUnicodeIdentifierStart(int codePoint)

确定是否允许将指定字符(Unicode 代码点)作为 Unicode 标识符中的首字符。

static boolean isUpperCase(char ch)

确定指定字符是否为大写字母。

static boolean isUpperCase(int codePoint)

确定指定字符(Unicode 代码点)是否为大写字母。

static boolean isValidCodePoint(int codePoint)

确定指定的代码点是否为从 0x0000 到 0x10FFFF 范围之内的有效 Unicode 代码点值。

static boolean isWhitespace(char ch)

确定指定字符依据 Java 标准是否为空白字符。

static boolean isWhitespace(int codePoint)

确定指定字符(Unicode 代码点)依据 Java 标准是否为空白字符。

static int offsetByCodePoints(char[] a, int start, int count, int index, int codePointOffset)

返回给定 char 子数组中的索引,它是从给定 index 到 codePointOffset 代码点的偏移量。

static int offsetByCodePoints(CharSequence seq, int index, int codePointOffset)

返回给定字符序列中的索引,它是从给定 index 到 codePointOffset 代码点的偏移量。

static char reverseBytes(char ch)

返回通过反转指定 char 值中的字节顺序而获得的值。

static char[] toChars(int codePoint)

将指定的字符(Unicode 代码点)转换成其存储在 char 数组中的 UTF-16 表示形式。

static int toChars(int codePoint, char[] dst, int dstIndex)

将指定字符(Unicode 代码点)转换为其 UTF-16 表示形式。

static int toCodePoint(char high, char low)

将指定的代理项对转换为其增补代码点值。

static char toLowerCase(char ch)

使用取自 UnicodeData 文件的大小写映射信息将字符参数转换为小写。

static int toLowerCase(int codePoint)

使用取自 UnicodeData 文件的大小写映射信息将字符(Unicode 代码点)参数转换为小写。

String toString()

返回表示此 Character 值的 String 对象。

static String toString(char c)

返回一个表示指定 char 值的 String 对象。

static char toTitleCase(char ch)

使用取自 UnicodeData 文件的大小写映射信息将字符参数转换为首字母大写。

static int toTitleCase(int codePoint)

使用取自 UnicodeData 文件的大小写映射信息将字符(Unicode 代码点)参数转换为首字母大写。

static char toUpperCase(char ch)

使用取自 UnicodeData 文件的大小写映射信息将字符参数转换为大写。

static int toUpperCase(int codePoint)

使用取自 UnicodeData 文件的大小写映射信息将字符(Unicode 代码点)参数转换为大写。

static Character valueOf(char c)

返回一个表示指定 char 值的 Character 实例

string所有方法:

char charAt(int index)

返回指定索引处的 char 值。

int codePointAt(int index)

返回指定索引处的字符(Unicode 代码点)。

int codePointBefore(int index)

返回指定索引之前的字符(Unicode 代码点)。

int codePointCount(int beginIndex, int endIndex)

返回此 String 的指定文本范围中的 Unicode 代码点数。

int compareTo(String anotherString)

按字典顺序比较两个字符串。

int compareToIgnoreCase(String str)

按字典顺序比较两个字符串,不考虑大小写。

String concat(String str)

将指定字符串连接到此字符串的结尾。

boolean contains(CharSequence s)

当且仅当此字符串包含指定的 char 值序列时,返回 true。

boolean contentEquals(CharSequence cs)

将此字符串与指定的 CharSequence 比较。

boolean contentEquals(StringBuffer sb)

将此字符串与指定的 StringBuffer 比较。

static String copyValueOf(char[] data)

返回指定数组中表示该字符序列的 String。

static String copyValueOf(char[] data, int offset, int count)

返回指定数组中表示该字符序列的 String。

boolean endsWith(String suffix)

测试此字符串是否以指定的后缀结束。

boolean equals(Object anObject)

将此字符串与指定的对象比较。

boolean equalsIgnoreCase(String anotherString)

将此 String 与另一个 String 比较,不考虑大小写。

static String format(Locale l, String format, Object... args)

使用指定的语言环境、格式字符串和参数返回一个格式化字符串。

static String format(String format, Object... args)

使用指定的格式字符串和参数返回一个格式化字符串。

byte[] getBytes()

使用平台的默认字符集将此 String 编码为 byte 序列,并将结果存储到一个新的 byte 数组中。

byte[] getBytes(Charset charset)

使用给定的 charset 将此 String 编码到 byte 序列,并将结果存储到新的 byte 数组。

void getBytes(int srcBegin, int srcEnd, byte[] dst, int dstBegin)

已过时。 该方法无法将字符正确转换为字节。从 JDK 1.1 起,完成该转换的首选方法是通过 getBytes() 方法,该方法使用平台的默认字符集。

byte[] getBytes(String charsetName)

使用指定的字符集将此 String 编码为 byte 序列,并将结果存储到一个新的 byte 数组中。

void getChars(int srcBegin, int srcEnd, char[] dst, int dstBegin)

将字符从此字符串复制到目标字符数组。

int hashCode()

返回此字符串的哈希码。

int indexOf(int ch)

返回指定字符在此字符串中第一次出现处的索引。

int indexOf(int ch, int fromIndex)

返回在此字符串中第一次出现指定字符处的索引,从指定的索引开始搜索。

int indexOf(String str)

返回指定子字符串在此字符串中第一次出现处的索引。

int indexOf(String str, int fromIndex)

返回指定子字符串在此字符串中第一次出现处的索引,从指定的索引开始。

String intern()

返回字符串对象的规范化表示形式。

boolean isEmpty()

当且仅当 length() 为 0 时返回 true。

int lastIndexOf(int ch)

返回指定字符在此字符串中最后一次出现处的索引。

int lastIndexOf(int ch, int fromIndex)

返回指定字符在此字符串中最后一次出现处的索引,从指定的索引处开始进行反向搜索。

int lastIndexOf(String str)

返回指定子字符串在此字符串中最右边出现处的索引。

int lastIndexOf(String str, int fromIndex)

返回指定子字符串在此字符串中最后一次出现处的索引,从指定的索引开始反向搜索。

int length()

返回此字符串的长度。

boolean matches(String regex)

告知此字符串是否匹配给定的正则表达式。

int offsetByCodePoints(int index, int codePointOffset)

返回此 String 中从给定的 index 处偏移 codePointOffset 个代码点的索引。

boolean regionMatches(boolean ignoreCase, int toffset, String other, int ooffset, int len)

测试两个字符串区域是否相等。

boolean regionMatches(int toffset, String other, int ooffset, int len)

测试两个字符串区域是否相等。

String replace(char oldChar, char newChar)

返回一个新的字符串,它是通过用 newChar 替换此字符串中出现的所有 oldChar 得到的。

String replace(CharSequence target, CharSequence replacement)

使用指定的字面值替换序列替换此字符串所有匹配字面值目标序列的子字符串。

String replaceAll(String regex, String replacement)

使用给定的 replacement 替换此字符串所有匹配给定的正则表达式的子字符串。

String replaceFirst(String regex, String replacement)

使用给定的 replacement 替换此字符串匹配给定的正则表达式的第一个子字符串。

String[] split(String regex)

根据给定正则表达式的匹配拆分此字符串。

String[] split(String regex, int limit)

根据匹配给定的正则表达式来拆分此字符串。

boolean startsWith(String prefix)

测试此字符串是否以指定的前缀开始。

boolean startsWith(String prefix, int toffset)

测试此字符串从指定索引开始的子字符串是否以指定前缀开始。

CharSequence subSequence(int beginIndex, int endIndex)

返回一个新的字符序列,它是此序列的一个子序列。

String substring(int beginIndex)

返回一个新的字符串,它是此字符串的一个子字符串。

String substring(int beginIndex, int endIndex)

返回一个新字符串,它是此字符串的一个子字符串。

char[] toCharArray()

将此字符串转换为一个新的字符数组。

String toLowerCase()

使用默认语言环境的规则将此 String 中的所有字符都转换为小写。

String toLowerCase(Locale locale)

使用给定 Locale 的规则将此 String 中的所有字符都转换为小写。

String toString()

返回此对象本身(它已经是一个字符串!)。

String toUpperCase()

使用默认语言环境的规则将此 String 中的所有字符都转换为大写。

String toUpperCase(Locale locale)

使用给定 Locale 的规则将此 String 中的所有字符都转换为大写。

String trim()

返回字符串的副本,忽略前导空白和尾部空白。

static String valueOf(boolean b)

返回 boolean 参数的字符串表示形式。

static String valueOf(char c)

返回 char 参数的字符串表示形式。

static String valueOf(char[] data)

返回 char 数组参数的字符串表示形式。

static String valueOf(char[] data, int offset, int count)

返回 char 数组参数的特定子数组的字符串表示形式。

static String valueOf(double d)

返回 double 参数的字符串表示形式。

static String valueOf(float f)

返回 float 参数的字符串表示形式。

static String valueOf(int i)

返回 int 参数的字符串表示形式。

static String valueOf(long l)

返回 long 参数的字符串表示形式。

static String valueOf(Object obj)

返回 Object 参数的字符串表示形式

c++数据结构,拜托帮帮忙,这题什么意思,要怎样做?

BagOfIntegers::BagOfIntegers() : itemCount(0), maxItems(DEFAULT_BAG_SIZE){}是构造函数,进行函数初始化,应该是缺少BagInterface.h 头文件,需要编写。

根据 class BagOfIntegers : public BagInterfaceint知道是公有继承,所以,BagInterface.h 的公有成员和BagOfIntergers一样的,结构形式和变量可以自己研究一下。

共有继承:1 共有继承不改变基类成员在派生类中的访问权限。在共有继承下,基类的public成员,protect成员,private成员在派生类中保持它们在基类中相同的访问权限。2 在派生类中定义的成员函数不能直接访问基类的私有成员,只能通过public或protect成员函数访问。私有继承:1 基类的private和protect都在派生类中变成了private成员,不能被派生类的外部函数访问。2 派生类的成员函数不能访问基类的private成员,但可以访问基类的public和protect成员,并通过它们访问基类private成员。

所以这是一个根据派生类写基类的逆向思维的题

lastIndexOf查找数组字符串和indexof效果一样了

1.searchValue

一个字符串,表示被查找的值。

2.fromIndex

从调用该方法字符串的此位置处开始查找。可以是任意整数。默认值为 str.length。如果为负值,则被看作 0。如果 fromIndex str.length,则 fromIndex 被看作 str.length。

区分大小写

lastIndexOf 方法区分大小写。例如,下面的表达式返回 -1:

?

1

"Blue Whale, Killer Whale".lastIndexOf("blue"); // returns -1

lastIndexOf的用法

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

// Create an array.

var ar = ["ab", "cd", "ef", "ab", "cd"];

// 找到最后一个CD的位置

document.write(ar.lastIndexOf("cd") + "br/");

// 输出: 4

// 从正数第二个位置,搜索倒数第一个CD的位置

document.write(ar.lastIndexOf("cd", 2) + "br/");

// 输出: 1

// 从倒数第三个搜索最后一个ab的位置

document.write(ar.lastIndexOf("ab", -3) + "br/");

// 输出: 0

同样 String.lastIndexOf的用法类似

?

1

2

3

4

"canal".lastIndexOf("a") // returns 3

"canal".lastIndexOf("a",2) // returns 1

"canal".lastIndexOf("a",0) // returns -1 从第0个往前搜,不存在'a',返回-1

"canal".lastIndexOf("x") // returns -1

lastIndexOf的IE8实现

不过微软的IE8及其以下并不支持Array.lastIndexOf,需要兼容实现。可以参考:

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

if (!Array.prototype.lastIndexOf) {

Array.prototype.lastIndexOf = function(searchElement /*, fromIndex*/) {

'use strict';

if (this === void 0 || this === null) {

throw new TypeError();

}

var n, k,

t = Object(this),

len = t.length 0;

if (len === 0) {

return -1;

}

n = len - 1;

if (arguments.length 1) {

n = Number(arguments[1]);

if (n != n) {

n = 0;

}

else if (n != 0 n != (1 / 0) n != -(1 / 0)) {

n = (n 0 || -1) * Math.floor(Math.abs(n));

}

}

for (k = n = 0

? Math.min(n, len - 1)

: len - Math.abs(n); k = 0; k--) {

if (k in t t[k] === searchElement) {

return k;

}

}

return -1;

};

}

可以使用 ES5-Slim 使旧版浏览器完全兼容ES5语法。

string类的表达式怎么算java

PHP中文网

Java中String字符串运算的介绍(代码示例)

?

php中文网课程

回答于 2019-02-11

本篇文章给大家带来的内容是关于Java中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码对应的值相对比判断是大写字母、小写字母、数字,计数打印。

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

/**

* @ author: PrincessHug

* @ date: 2019/2/7, 17:09

* @ Blog:

*/

publicclassStringAPIDemo {

/**

* 需求:计算字符串中大写字母、小写字母、数字出现的次数

* @param args 参数

*/

publicstaticvoid main(String[] args) {

//通过用户输入得到一个字符串

String str = getString();

getCount(str);

}

privatestaticvoid 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);

}

privatestaticString getString() {

System.out.println("请输入一个字符串:");

Scanner scanner =newScanner(System.in);

String s = scanner.nextLine();

returns;

}

}

需求二:查询父字符串中某一个子字符串出现的次数

思路1:使用indexOf方法查询子字符串第一次出现的索引a,再使用subString方法返回父字符串索引(a+子字符串长度)之后的字符串,并计数+1,循环该操作知道indexOf方法返回值为-1停止,获取计数值即可。

思路2:使用split方法将父字符串按照子字符串进行切分得到String数组,使用subString方法获取父字符串最后的字符串是否等于子字符串,若等于,返回String数组的length长度;若不等,则返回String数组的length-1.

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

**

* @ author: PrincessHug

* @date: 2019/2/7, 17:34

* @ Blog:

*/

publicclassFindChildStringCount {

/**

* 需求:查询父字符串中某一个子字符串的数量

* @param args

*/

publicstaticvoid 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 +"次。");

}

privatestaticint getChildStringCount02(String parent, String child) {

String[] s = parent.split(child);

if(child.equals(parent.substring(parent.length()-child.length()))){

returns.length;

}else{

returns.length-1;

}

}

privatestaticint getChildStringCount01(String parent,String child) {

int num = 0;

int index = 0;

while((index = parent.indexOf(child)) != -1){

num++;

parent = parent.substring(index + child.length());

}

returnnum;

}

privatestaticint 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();

}

returnsum==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修改为对应的正则表达式即可。

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

/**

* @ author: PrincessHug

* @ date: 2019/2/7, 21:51

* @ Blog:

*/

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 =newScanner(System.in);

System.out.println("请输入您的qq号");

String s = sc.nextLine();

returns;

}

/**

* 验证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}";

returnregex;

}

}

正则表达式“或“的使用

正则表达式,又称规则表达式。是计算机科学的一个概念。

正则表达式通常被用来检索、替换那些符合某个模式(规则)的文本。许多程序设计语言都支持利用正则表达式进行字符串操作。例如,在Perl中就内建了一个功能强大的正则表达式引擎。正则表达式这个概念最初是由Unix中的工具软件(例如sed和grep)普及开的。

正则表达式通常缩写成“regex”,单数有regexp、regex,复数有regexps、regexes、regexen。

扩展资料

正则表达式的作用:

1、匹配

检查字符串是否符合正则表达式中的规则,有一次不匹配,则返回false。如:

String str="abc";

String reg="[a-zA-Z]\\d?";//次表达式表示字符串的第一位只能是字母,第二位只能是数字或没有boolean flag=str.matches(reg);//返回结果为true。

2、切割

所谓切割,即是按一定的规则将字符串分割成多个子字符串,如:

String str="zhangsan,lishi,wangwu"。

String reg=",";//表示以逗号作为切割符。

String[] arr=str.split(reg);//返回结果为{“zhangsan”,"lisi","wangwu}。

3、替换

即将字符串中符合规则的字符替换成指定字符,如:

String str="sfhjhfh136hjasdf73466247fsjha8437482jfjsfh746376"。

str.replaceAll("\\d{3,}","#");//表示将连续出现三个或三个以上的数字替换成“#”。

参考资料来源:百度百科-正则表达式

(责任编辑:IT教学网)

更多

推荐XML/XSLT文章