Как удалить ведущие нули из буквенно-цифрового текста?

StackOverflow https://stackoverflow.com/questions/2800739

  •  25-09-2019
  •  | 
  •  

Вопрос

Я видел вопросы о том, как префикс нулей здесь так. Но не наоборот!

Вы можете предложить мне, как удалить ведущие нули в буквенно-цифровом тексте? Есть ли встроенные API или мне нужно написать метод для обрезки ведущих нулей?

Пример:

01234 converts to 1234
0001234a converts to 1234a
001234-a converts to 1234-a
101234 remains as 101234
2509398 remains as 2509398
123z remains as 123z
000002829839 converts to 2829839
Это было полезно?

Решение

Regex - лучший инструмент для работы; Что должно быть зависит от спецификации проблемы. Следующее удаляет ведущие нули, но оставляет один при необходимости (т.е. это не просто повернут "0" в пустую строку).

s.replaceFirst("^0+(?!$)", "")

То ^ Якорь удостоверится, что 0+ Быть сопоставленным в начале ввода. То (?!$) Отрицательный поиск гарантирует, что не вся строка будет соответствовать.

Тестовый жгут:

String[] in = {
    "01234",         // "[1234]"
    "0001234a",      // "[1234a]"
    "101234",        // "[101234]"
    "000002829839",  // "[2829839]"
    "0",             // "[0]"
    "0000000",       // "[0]"
    "0000009",       // "[9]"
    "000000z",       // "[z]"
    "000000.z",      // "[.z]"
};
for (String s : in) {
    System.out.println("[" + s.replaceFirst("^0+(?!$)", "") + "]");
}

Смотрите также

Другие советы

Вы можете использовать Stringutils. класс от Apache Commons Lang так:

StringUtils.stripStart(yourString,"0");

Как насчет повторного выражения:

String s = "001234-a";
s = s.replaceFirst ("^0*", "");

То ^ Якоря до начала строки (я предполагаю, что из контекста ваши строки здесь не являются многострочными здесь, в противном случае вам может потребоваться посмотреть \A для начала ввода, а не начала строки). То 0* значит ноль или больше 0 персонажи (вы мог использовать 0+ также). То replaceFirst просто заменяет все те 0 персонажи на старте с ничего.

И если, как Вадзим, ваше определение ведущих Zeros не включает поворот "0" (или "000" или похожие строки) в пустую строку (достаточно рациональное ожидание), просто положите его назад, если необходимо:

String s = "00000000";
s = s.replaceFirst ("^0*", "");
if (s.isEmpty()) s = "0";

Чистый способ без каких-либо потребностей в регуляции Regexp и любых внешних библиотек.

public static String trimLeadingZeros(String source) {
    for (int i = 0; i < source.length(); ++i) {
        char c = source.charAt(i);
        if (c != '0') {
            return source.substring(i);
        }
    }
    return ""; // or return "0";
}

Идти с Apache Thelost Apache Commons: Использование ГУАВА-Библиотеки (Библиотека общего назначения Google Java, которую я буду спорить, теперь должен быть в классе какого-либо нетривиального проекта Java), это будет использовать Шарчачатель:

CharMatcher.is('0').trimLeadingFrom(inputString);

Используйте Apache Commons. StringUtils сорт:

StringUtils.strip(String str, String stripChars);

Вы могли бы просто сделать:String s = Integer.valueOf("0001007").toString();

Использование Regexp с группами:

Pattern pattern = Pattern.compile("(0*)(.*)");
String result = "";
Matcher matcher = pattern.matcher(content);
if (matcher.matches())
{
      // first group contains 0, second group the remaining characters
      // 000abcd - > 000, abcd
      result = matcher.group(2);
}

return result;

Использовать этот:

String x = "00123".replaceAll("^0*", ""); // -> 123

Использование Regeex Как некоторые из ответов предлагают это хороший способ сделать это. Если вы не хотите использовать Regex, вы можете использовать этот код:

String s = "00a0a121";

while(s.length()>0 && s.charAt(0)=='0')
{
   s = s.substring(1); 
}

Я думаю, что это так легко сделать. Вы можете просто петить по строке с начала и удаления нулей до тех пор, пока не найдут не нулевой символ.

int lastLeadZeroIndex = 0;
for (int i = 0; i < str.length(); i++) {
  char c = str.charAt(i);
  if (c == '0') {
    lastLeadZeroIndex = i;
  } else {
    break;
  }
}

str = str.subString(lastLeadZeroIndex+1, str.length());

Если вы (например, я) нужно удалить все ведущие нули из каждого «слова» в строке, вы можете изменить ответ @Polygenelubricant на следующее:

String s = "003 d0g 00ss 00 0 00";
s.replaceAll("\\b0+(?!\\b)", "");

который приводит к:

3 d0g ss 0 0 0

Если вы используете Kotlin, это единственный код, который вам нужен:

yourString.trimStart('0')

Вы могли бы заменить "^0*(.*)" к "$1" с регелем

       String s="0000000000046457657772752256266542=56256010000085100000";      
    String removeString="";

    for(int i =0;i<s.length();i++){
      if(s.charAt(i)=='0')
        removeString=removeString+"0";
      else 
        break;
    }

    System.out.println("original string - "+s);

    System.out.println("after removing 0's -"+s.replaceFirst(removeString,""));

Если вы не хотите использовать Regex или внешнюю библиотеку. Вы можете сделать с «для»:

String input="0000008008451"
String output = input.trim();
for( ;output.length() > 1 && output.charAt(0) == '0'; output = output.substring(1));

System.out.println(output);//8008451

Я сделал несколько тестов и нашел, что самый быстрый путь (безусловно) это решение:

    private static String removeLeadingZeros(String s) {
      try {
          Integer intVal = Integer.parseInt(s);
          s = intVal.toString();
      } catch (Exception ex) {
          // whatever
      }
      return s;
    }

Особенно регулярные выражения очень медленно в длительной итерации. (Мне нужно было выяснить самый быстрый путь для бачуса.)

Без использования Regex или substring() функция включения String который будет неэффективным -

public static String removeZero(String str){
        StringBuffer sb = new StringBuffer(str);
        while (sb.length()>1 && sb.charAt(0) == '0')
            sb.deleteCharAt(0);
        return sb.toString();  // return in String
    }

А как насчет поиска первого ненулевого персонажа?

[1-9]\d+

Это регулярное выражение находит первую цифру между 1 и 9, а затем любой номер цифр, поэтому для "00012345" Это возвращает "12345"Отказ Это может быть легко адаптировано для буквенно-цифровых струн.

Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top