Вопрос

Какой была бы простая реализация метода для преобразования строки типа "Привет всем" в "helloThereEveryone".В JavaME поддержка операций утилиты String и StringBuffer довольно ограничена.

Это было полезно?

Решение

Быстрая примитивная реализация. Я понятия не имею об ограничениях J2ME, поэтому я надеюсь, что он подходит или дает какие-то идеи ...

String str = "Hello, there, everyone?";

StringBuffer result = new StringBuffer(str.length());
String strl = str.toLowerCase();
boolean bMustCapitalize = false;
for (int i = 0; i < strl.length(); i++)
{
  char c = strl.charAt(i);
  if (c >= 'a' && c <= 'z')
  {
    if (bMustCapitalize)
    {
      result.append(strl.substring(i, i+1).toUpperCase());
      bMustCapitalize = false;
    }
    else
    {
      result.append(c);
    }
  }
  else
  {
    bMustCapitalize = true;
  }
}
System.out.println(result);

Вы можете заменить сложную заглавную букву на:

result.append((char) (c - 0x20));

хотя это может показаться более хакерским.

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

С CDC у вас есть:

String.getBytes (); // для преобразования строки в массив байтов String.indexOf (int ch); // для поиска начала слов String.trim (); // для удаления пробелов

В нижнем / верхнем регистре нужно добавить (вычесть) 32.

С помощью этих элементов вы можете создать свой собственный метод.

private static String toCamelCase(String s) {
    String result = "";
    String[] tokens = s.split("_"); // or whatever the divider is
    for (int i = 0, L = tokens.length; i<L; i++) {
        String token = tokens[i];
        if (i==0) result = token.toLowerCase();
        else
            result += token.substring(0, 1).toUpperCase() +
                token.substring(1, token.length()).toLowerCase();
    }
    return result;
}

Предложение:

Может быть, если ты сможешь перенесите одну библиотеку регулярных выражений на J2ME, вы могли бы использовать его для удаления пробелов в вашей строке...

Попробуйте следующий код

public static String toCamel(String str) {
    String rtn = str;
    rtn = rtn.toLowerCase();
    Matcher m = Pattern.compile("_([a-z]{1})").matcher(rtn);
    StringBuffer sb = new StringBuffer();
    while (m.find()) {
        m.appendReplacement(sb, m.group(1).toUpperCase());
    }
    m.appendTail(sb);
    rtn = sb.toString();
    return rtn;
}

Я бы предложил следующий простой код:

    String camelCased = "";
    String[] tokens = inputString.split("\\s");
    for (int i = 0; i < tokens.length; i++) {
        String token = tokens[i];
        camelCased = camelCased + token.substring(0, 1).toUpperCase() + token.substring(1, token.length());
    }
    return camelCased;

Я бы сделал это так:

private String toCamelCase(String s) {
    StringBuffer sb = new StringBuffer();
    String[] x = s.replaceAll("[^A-Za-z]", " ").replaceAll("\\s+", " ")
            .trim().split(" ");

    for (int i = 0; i < x.length; i++) {
        if (i == 0) {
            x[i] = x[i].toLowerCase();
        } else {
            String r = x[i].substring(1);
            x[i] = String.valueOf(x[i].charAt(0)).toUpperCase() + r;

        }
        sb.append(x[i]);
    }
    return sb.toString();
}

проверьте это

import org.apache.commons.lang.WordUtils;

String camel = WordUtils.capitalizeFully('I WANT TO BE A CAMEL', new char[]{' '});

return camel.replaceAll(" ", "");
Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top