簡體   English   中英

從字符串獲取子字符串(我從文本文件獲取字符串)

[英]getting substrings from a string (i get the string from a text file)

我正在嘗試將我的消息聊天,以使事情看起來像這樣:

在此處輸入圖片說明

這是我的消息字符串:

String messages = "Me said: Hola\n"+
                  "Steven said: Hola android client\n"+
                  "Me said: como estas ?\n"+
                  "Steven said: Yo muy bien y tu?\n"+
                  "Me said: bueno si esto funciona me sentire magnifico ;)\n"+
                 "Me said: ah cierto me olvidaba veamos si dos mensajes seguidos funcionan\n"+
                 "Steven said: bien\nVeamos si funciona\n"+
                 "Me said: se xd\n";

我試圖這樣做,以使其讀取每一行:

    while(messagesToRead.contains("Me said:") || messagesToRead.contains("Steven said:")){
        if(messagesToRead.indexOf("Me said:")==0)
          {
            // 8 because 'Me said:' size is 8 , -1 because i don't want to read the last  \n
            String messageToAdd=messagesToRead.substring(8,(messagesToRead.indexOf("Steven said:"))-1);
            // if the first @param is false i set it to right
            adapter.add(new DataProvider(false,messageToAdd));
            messagesToRead = messagesToRead.substring(messageToAdd.length()+9);
          }
         else if(messagesToRead.indexOf("Steven said:")== 0)
          {
            // 12 because of 'Steven said:' size
            String messageToAdd=messagesToRead.substring(12,messagesToRead.indexOf("Me said:")-1);
            adapter.add(new DataProvider(true,messageToAdd));
            messagesToRead = messagesToRead.substring(messageToAdd.length()+13);
           } 

        }

我知道我在邏輯上有問題,這不是讀取每一行的最佳方法,但我現在只是想使其以這種方式工作。

這應該工作。 我剛剛測試過。

    String messagesToRead = "Me said: Hola\n"+
                    "Steven said: Hola android client\n"+
                    "Me said: como estas ?\n"+
                    "Steven said: Yo muy bien y tu?\n"+
                    "Me said: bueno si esto funciona me sentire magnifico ;)\n"+
                   "Me said: ah cierto me olvidaba veamos si dos mensajes seguidos funcionan\n"+
                   "Steven said: bien\nVeamos si funciona\n"+
                   "Me said: se xd\n";

            String[] messages= messagesToRead.split("\n");
            ArrayList<String> arr = new ArrayList<String>(Arrays.asList(messages));
            messages=null;
            String pattern1 = "Me said:";
            String pattern2 = "Steven said:";
            int size =  arr.size(); //you need to have the initial size before processing
             // lines you are talking about
             for(int i=size-1;i>=0;i--)
             {
                  String str = arr.get(i);
                  if(str!="" && str.indexOf(pattern1)==-1 && str.indexOf(pattern2)==-1)
                  {
                     String tmp = arr.remove(i);
                     String old =arr.get(i-1) ;
                     arr.set(i-1,old+"\n"+tmp);
                  }
             } 

            messages = new String[arr.size()];
            messages = arr.toArray(messages);

            for(String mess : messages)
            {
                if(mess!="" && mess.indexOf(pattern2) == 0)
                {
                     /*code here*/
                    System.out.println(mess);
                }
            }

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM