Как выполнить замену только на фрагменте текста, который соответствует шаблону [дубликат]

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

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

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 ");
        }
    }
}
11
задан bard 29 October 2014 в 16:02
поделиться

4 ответа

Используйте отрицательный lookghead для соответствия всем запятым, которые не находятся внутри скобки. Разделение входной строки в соответствии с согласованными запятыми даст вам желаемый результат.

,\s*(?![^()]*\))

DEMO

>>> import re
>>> s = "Water, Titanium Dioxide (CI 77897), Black 2 (CI 77266), Iron Oxides (CI 77491, 77492, 77499), Ultramarines (CI 77007)"
>>> re.split(r',\s*(?![^()]*\))', s)
['Water', 'Titanium Dioxide (CI 77897)', 'Black 2 (CI 77266)', 'Iron Oxides (CI 77491, 77492, 77499)', 'Ultramarines (CI 77007)']
15
ответ дан Avinash Raj 18 August 2018 в 17:11
поделиться
  • 1
    regex101.com снова наносит удар! :) (я просто прокомментировал здесь об этом еще час назад) – shadi 27 July 2018 в 17:17

Используя regex, это можно легко сделать с помощью функции findall.

import re
s = "Titanium Dioxide (CI 77897), Black 2 (CI 77266), Iron Oxides (CI 77491, 77492, 77499), Ultramarines (CI 77007)"
re.findall(r"\w.*?\(.*?\)", s) # returns what you want

Используйте http://www.regexr.com/ , если вы лучше понять регулярное выражение, и вот ссылка на документацию на python: https://docs.python.org/2/library/re.html

EDIT: I изменил строку регулярного выражения, чтобы принять содержимое без круглых скобок: \w[^,(]*(?:\(.*?\))?

0
ответ дан asimoneau 18 August 2018 в 17:11
поделиться

Попробуйте код regex

[^()]*\([^()]*\),?

:

>>x="Titanium Dioxide (CI 77897), Black 2 (CI 77266), Iron Oxides (CI 77491, 77492, 77499), Ultramarines (CI 77007)"
>> re.findall("[^()]*\([^()]*\),?",x)
['Titanium Dioxide (CI 77897),', ' Black 2 (CI 77266),', ' Iron Oxides (CI 77491, 77492, 77499),', ' Ultramarines (CI 77007)']

посмотреть, как работает регулярное выражение http://regex101.com/r/pS9oV3/1

0
ответ дан nu11p01n73R 18 August 2018 в 17:11
поделиться

Вы можете просто сделать это, используя str.replace и str.split. Вы можете использовать любой символ для замены ),.

a = "Titanium Dioxide (CI 77897), Black 2 (CI 77266), Iron Oxides (CI 77491, 77492, 77499), Ultramarines (CI 77007)"
a = a.replace('),', ')//').split('//')
print a

вывод: -

['Titanium Dioxide (CI 77897)', ' Black 2 (CI 77266)', ' Iron Oxides (CI 77491, 77492, 77499)', ' Ultramarines (CI 77007)']
2
ответ дан Vishnu Upadhyay 18 August 2018 в 17:11
поделиться
Другие вопросы по тегам:

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