sed или awk: заменить \ n из выбранных нескольких строк

Исключение нулевого указателя - это индикатор того, что вы используете объект, не инициализируя его.

Например, ниже - класс ученика, который будет использовать его в нашем коде.

public class Student {

    private int id;

    public int getId() {
        return this.id;
    }

    public setId(int newId) {
        this.id = newId;
    }
}

Приведенный ниже код дает вам исключение с нулевым указателем.

public class School {

    Student obj_Student;

    public School() {
        try {
            obj_Student.getId();
        }
        catch(Exception e) {
            System.out.println("Null Pointer ");
        }
    }
}

Поскольку вы используете Obj_Student, но вы забыли инициализировать его, как в правильном коде, показанном ниже:

public class School {

    Student obj_Student;

    public School() {
        try {
            obj_Student = new Student();
            obj_Student.setId(12);
            obj_Student.getId();
        }
        catch(Exception e) {
            System.out.println("Null Pointer ");
        }
    }
}
-1
задан oguz ismail 14 April 2019 в 06:46
поделиться

2 ответа

если ваши данные в файле 'd', попробуйте gnu sed,

sed -E '/<table>/{:a N;/.*\n<\/table>/!ba;s/\n//g;} ' d
0
ответ дан abdan 14 April 2019 в 06:46
поделиться
awk '/<table>/{ORS=""} /<\/table>/{ORS=RS} 1' file 

для каждой строки:

  • , если <table> найден, набор Output Record Separator к пустой строке (""),
  • , если </table> найден, восстановление ORS,
  • печать.

посмотрите этот демонстрация онлайн .

примечание, что это могло бы работать на Ваш образец, но очевидно не будет работать на весь table элементы. см. , почему парсинг HTML с помощью regex является плохой практикой .

0
ответ дан oguz ismail 15 April 2019 в 01:41
поделиться
Другие вопросы по тегам:

Похожие вопросы: