• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

java / hashmap

Object Storage Arubacloud
0 głosów
229 wizyt
pytanie zadane 20 grudnia 2018 w Java przez Piotr Kusnierkiewicz Użytkownik (670 p.)
edycja 20 grudnia 2018 przez Piotr Kusnierkiewicz

Czy ktos wie dlaczego moja mapa nie przyjmuje nastepnego klucza tylko tak jakby sie nadpisuje ? :

prosze o podpowiedzi

 
 

package logReaderCode;

import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.FileReader;
import java.io.FileWriter;
import java.io.IOException;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.regex.Matcher;
import java.util.regex.Pattern;

public class Main {

    
    
    static Map<String, List<String>> myMaps = new HashMap<String, List<String>>();

    
    static BufferedReader br = null;
    static BufferedWriter bw = null;

    public static void main(String[] args) throws IOException {

        String line;
        String date = "";
        String codeNumber = "";
        String saveCustomerId = "";
        String time = "";

        String[] fileOut = { "C:\\\\foundation\\\\eclipsecode\\\\logReaderCode\\\\output2018-09-10.txt",
                "C:\\\\foundation\\\\eclipsecode\\\\logReaderCode\\\\output2018-09-26.txt",
                "C:\\\\foundation\\\\eclipsecode\\\\logReaderCode\\\\output2018-09-27.txt",
                "C:\\\\foundation\\\\eclipsecode\\\\logReaderCode\\\\output2018-10-02.txt",
                "C:\\\\foundation\\\\eclipsecode\\\\logReaderCode\\\\output2018-10-03.txt",
                "C:\\\\foundation\\\\eclipsecode\\\\logReaderCode\\\\output2018-10-04.txt",
                "C:\\\\foundation\\\\eclipsecode\\\\logReaderCode\\\\output2018-10-12.txt",
                "C:\\\\foundation\\\\eclipsecode\\\\logReaderCode\\\\output2018-10-17.txt",
                "C:\\\\foundation\\\\eclipsecode\\\\logReaderCode\\\\output2018-10-18.txt",
                "C:\\\\foundation\\\\eclipsecode\\\\logReaderCode\\\\output2018-10-20.txt" };

        String[] fileTest = { "C:\\\\foundation\\\\eclipsecode\\\\logReaderCode\\\\server.log.2018-09-10",
                "C:\\\\foundation\\\\eclipsecode\\\\logReaderCode\\\\server.log.2018-09-26",
                "C:\\\\foundation\\\\eclipsecode\\\\logReaderCode\\\\server.log.2018-09-27",
                "C:\\\\foundation\\\\eclipsecode\\\\logReaderCode\\\\server.log.2018-10-02",
                "C:\\\\foundation\\\\eclipsecode\\\\logReaderCode\\\\server.log.2018-10-03",
                "C:\\\\foundation\\\\eclipsecode\\\\logReaderCode\\\\server.log.2018-10-04",
                "C:\\\\foundation\\\\eclipsecode\\\\logReaderCode\\\\server.log.2018-10-12",
                "C:\\\\foundation\\\\eclipsecode\\\\logReaderCode\\\\server.log.2018-10-17",
                "C:\\\\foundation\\\\eclipsecode\\\\logReaderCode\\\\server.log.2018-10-18",
                "C:\\\\foundation\\\\eclipsecode\\\\logReaderCode\\\\server.log.2018-10-20" };

            br = new BufferedReader(new FileReader(fileTest[0]));
            bw = new BufferedWriter(new FileWriter(fileOut[0]));

            while ((line = br.readLine()) != null) {
                Matcher exception = Pattern.compile("Exception: com.sbbetting.core.exception.BetSlipCreatorException")
                        .matcher(line);
                Matcher code44 = Pattern.compile("Code: 44").matcher(line);
                Matcher code15 = Pattern.compile("Code: 15").matcher(line);

                if (exception.find()) {
                    if (code44.find() || code15.find()) {
                        date = line.substring(0, 10);
                        time = line.substring(11, 19);
                        codeNumber = line.substring(217, 225).replace("Code:", "").replace("ode:", "").replace(",", "").replace("de:", "").replace(" ", "");
                        line = br.readLine();
                        line = br.readLine();
                        saveCustomerId = line.substring(line.indexOf('=') + 1, line.indexOf('=') + 6);
                        classCodeNumber(codeNumber, date , time , saveCustomerId);                            
                        showCodeNumber();                        
                    }
                    
                }

            }
        

            bw.close();
            br.close();
        }
    
    
    private static void classCodeNumber(String codeNumber, String date, String time, String customerId) {
        List<String> list = new ArrayList<>();
        String codeNumberString = "{" + date + "}" + ";" + "{" + time + "}" + ";" + "{" + "id: " + customerId + "}"
                + ";" + "{" + codeNumber + "}" + "\r\n";

        if (codeNumber != null || date != null || time != null || customerId != null) {

            list.add(codeNumberString);

        }
            myMaps.put(codeNumber, list);
    }

    
    
    
    public static List<String> showCodeNumber() throws IOException {

        List<String> value = new ArrayList<>();
        
        for (String name : myMaps.keySet()) {
            
                value = myMaps.get(name);
                                
        }
        bw.write(value.toString().replace("[", "").replace("]", ""));
        return value;    
    }
    

        
}

chodzi o ten warunek: bo zapisuje do pliku code15 a chce zeby zapisywalo oba

 if (code44.find() || code15.find())

 

2 odpowiedzi

0 głosów
odpowiedź 20 grudnia 2018 przez Piotr Kusnierkiewicz Użytkownik (670 p.)
nadpisywalem zmienna codeNumber, musialem stworzyć nastepna zmienna nie do konca rozumiem czemu ale pewnie musialbym miec liste zeby bylo inaczej . Działa !!!
0 głosów
odpowiedź 20 grudnia 2018 przez mbabane Szeryf (79,280 p.)

Wydaje mi się że lepiej by było gdyby ten codeNumber:

myMaps.put(codeNumber, list);

To nie był sklejony String tylko obiekt, który posiada pola w postaci tych Stringów:

class CodeNumber{
   String codeNumber, 
   String date,
   String time,
   String customerId;

//konstruktory itd.
}

 

A Twój problem mógł też wynikać z ogólnego działa HashMapy. Trzeba by dokładniej przeanalizować kod co tam zachodzi bo być może nadpisujesz ten sam klucz w mapie.

Podobne pytania

0 głosów
1 odpowiedź 316 wizyt
pytanie zadane 27 kwietnia 2020 w Java przez danielo665 Obywatel (1,040 p.)
+1 głos
1 odpowiedź 248 wizyt
pytanie zadane 23 kwietnia 2022 w Java przez Czang Kai Shrek Obywatel (1,990 p.)
0 głosów
1 odpowiedź 152 wizyt
pytanie zadane 17 grudnia 2018 w Java przez Piotr Kusnierkiewicz Użytkownik (670 p.)

92,620 zapytań

141,474 odpowiedzi

319,813 komentarzy

62,004 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...