java 中substring() 方法的使用

在写一个判断文件格式的代码时,遇到了一些问题

1.按照下标截取子串

substring(int begin , int end); //截取从下标从begin到end的子串

2.截取某个字符或者某个字符串前面的子串

一个txt文件的内容如图一,我想获得文件头后面的内容 和 该编号对应的文件格式得到如图二的结果我应该怎么办?


很显然思路是

1.我们需要一行一行的读文件
2.获得每一行的前面和后面

针对1:BufferedReader 类中定义了按照行读取的方法,使用方法如下
//BufferedReader类的方法——br.readLine();
BufferedReader br = new BufferedReader(new FileReader(file));
String str ;
//while((str = br.readLine())!=null)实现了文件的按行存取
while((str = br.readLine()) != null) //读取文件退出条件
针对2:设计到一些substring()方法的一些冷门使用
while((str = br.readLine()) != null) //判断读取文件是否为空
{
   
//获得从开头到','的字符串,不带‘,’
     String value  = str.substring(0,str.indexOf(','));
//获得从‘:’后面的字符串,如果不加1的话,会带‘:’
     String key = str.substring(str.indexOf(':')+1);
     map.put(key,value);
}

这里关键是对String.indexOf()的使用
注:参数既可以是字符,也可以是字符串
str.indexOf(':');//返回:在str字符串的下标
str.indexof("ab" // 返回a在str字符串中的下标)

完整代码
import java.text.Normalizer;
import java.util.*;

public class InputStream3 {
   
    public static void main(String[] args) throws IOException {
   
// Byte[] frontByte = new Byte[10];
        File file = new File("file1.txt");
        Map<String , String> map  = new HashMap<>();
        BufferedReader br = new BufferedReader(new FileReader(file));
        String str ;

        while((str = br.readLine()) != null) //判断读取文件是否为空
        {
   
            String value  = str.substring(0,str.indexOf(','));
            String key = str.substring(str.indexOf(':')+1);
            map.put(key,value);
        }

        File file1 = new File("file2.jpg");
        for (String key : map.keySet()) {
   
            System.out.println(key+" "+map.get(key));
        }
// String substring = line.substring(line.indexOf(':')+1);
// System.out.println(substring);

    }
}