Java中s.charAt(index)用于提取字符串s中的特定字符操作

 更新时间:2020年10月08日 10:53:13   作者:L_Program  
这篇文章主要介绍了Java中s.charAt(index)用于提取字符串s中的特定字符操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧

charAt(int index)方法是一个能够用来检索特定索引下的字符的String实例的方法.

charAt()方法返回指定索引位置的char值。索引范围为0~length()-1.

如: str.charAt(0)检索str中的第一个字符,str.charAt(str.length()-1)检索最后一个字符.

警告:在字符串s中越界访问字符是一种常见的程序设计错误。为避免此类错误要确保使用的下标不会超过s.length()-1.

public class hash { 
 
 public static void main(String[] args) {
 // TODO Auto-generated method stub 
 
  String str = "This is yiibai"; 
  
  // prints character at 1st location
  System.out.println(str.charAt(0));  
  
  // prints character at 5th location i.e white-space character
  System.out.println(str.charAt(4));
  
  // prints character at 18th location
  System.out.println(str.charAt(6));
 }
}

结果如下:

补充知识:JAVA 提取字符串常用的两种方法(subString、正则表达式)

1.通过subString()方法来对字符串进行操作

subString()语法:

public String substring(int beginIndex)

public String substring(int beginIndex, int endIndex)

1、取得的字符串长度为:endIndex - beginIndex;

2、从beginIndex开始取,到endIndex结束,从0开始数,其中不包括endIndex位置的字符

示例:

    String str1="abdc686512ffsc1267d";
    String substr1=str1.substring(4);
    
    //指定区间(不包括结束索引处)
    String substr2=str1.substring(4, 10);
    System.out.println("substr1="+substr1);
    System.out.println("substr2="+substr2);
    System.out.println("*****************************");
    
    //结合使用indexOf()灵活截取示例
    String str2="<![CDATA[3-4级]]>";
    String cutstr=str2.substring(9, str2.indexOf("]]"));
    System.out.println("cutstr="+cutstr);

结果:

substr1=686512ffsc1267d
substr2=686512
*****************************
cutstr=3-4级

2.使用正则表达式+Pattern()和Matcher()

Pattern 类:

pattern 对象是一个正则表达式的编译表示。Pattern 类没有公共构造方法。要创建一个 Pattern 对象,你必须首先调用其公共静态编译方法,它返回一个 Pattern 对象。该方法接受一个正则表达式作为它的第一个参数。

Matcher 类:

Matcher 对象是对输入字符串进行解释和匹配操作的引擎。与Pattern 类一样,Matcher 也没有公共构造方法。你需要调用 Pattern 对象的 matcher 方法来获得一个 Matcher 对象。

完整示例

    System.out.println("正则表达式:");
    //正则表达式
    String str2="<![CDATA[3-4级]]>";
    String fengli="\\[CDATA\\[(.*?)\\]\\]>";//提取风级的正则表达式
    Pattern pafengli=Pattern.compile(fengli);
    Matcher matfengli = pafengli.matcher(str2);
    if(matfengli.find())
    {
     cutstr = matfengli.group(1); //group为捕获组
     System.out.println("cutstr="+cutstr);
    }
    else
     System.out.println("没找到");

正则表达式:

cutstr=3-4级

注意: String fengli="\\[CDATA\\[(.*?)\\]\\]>";中的斜杠为转义标志

以上这篇Java中s.charAt(index)用于提取字符串s中的特定字符操作就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • SpringBoot登录判断过程代码实例

    SpringBoot登录判断过程代码实例

    这篇文章主要介绍了SpringBoot登录判断代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-12-12
  • 教你如何更改IDEA项目的路径

    教你如何更改IDEA项目的路径

    这篇文章主要介绍了教你如何更改IDEA项目的路径,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-01-01
  • Java Code Cache满导致应用性能降低问题解决

    Java Code Cache满导致应用性能降低问题解决

    这篇文章主要介绍了Java Code Cache满导致应用性能降低问题解决,本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-08-08
  • java实现简单的弹球游戏

    java实现简单的弹球游戏

    这篇文章主要为大家详细介绍了java实现简单的弹球游戏,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-08-08
  • Spring中Bean的作用域和自动装配方式

    Spring中Bean的作用域和自动装配方式

    这篇文章主要介绍了Spring中Bean的作用域和自动装配方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-09-09
  • 多个SpringBoot项目采用redis实现Session共享功能

    多个SpringBoot项目采用redis实现Session共享功能

    这篇文章主要介绍了多个SpringBoot项目采用redis实现Session共享,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-09-09
  • Springcloud Config配置中心使用与相关介绍

    Springcloud Config配置中心使用与相关介绍

    springcloud config是一个解决分布式系统的配置管理方案。它包含了 client和server两个部分,server端提供配置文件的存储、以接口的形式将配置文件的内容提供出去,client端通过接口获取数据、并依据此数据初始化自己的应用
    2022-09-09
  • 使用restTemplate远程调controller路径取数据

    使用restTemplate远程调controller路径取数据

    这篇文章主要介绍了使用restTemplate远程调controller路径取数据,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-08-08
  • java.sql.SQLException:com.mysql.cj.jdbc.Driver报错问题解决

    java.sql.SQLException:com.mysql.cj.jdbc.Driver报错问题解决

    这篇文章主要给大家介绍了关于java.sql.SQLException:com.mysql.cj.jdbc.Driver报错问题解决的相关资料,文中通过图文介绍的非常详细,需要的朋友可以参考下
    2023-08-08
  • MyBatis-Plus中的逻辑删除使用详解

    MyBatis-Plus中的逻辑删除使用详解

    开发系统时,有时候在实现功能时,删除操作需要实现逻辑删除就是将数据标记为删除,而并非真的物理删除(非DELETE操作),查询时需要携带状态条件,确保被标记的数据不被查询到。这样做的目的就是避免数据被真正的删除
    2022-12-12

最新评论