Como posso converter uma string como 'helloThere' ou 'HelloThere' para 'Hello There' em JavaScript?
Como posso converter uma string como 'helloThere' ou 'HelloThere' para 'Hello There' em JavaScript?
Respostas:
var text = 'helloThereMister';
var result = text.replace( /([A-Z])/g, " $1" );
var finalResult = result.charAt(0).toUpperCase() + result.slice(1);
console.log(finalResult);
colocar em maiúscula a primeira letra - como um exemplo.
Observe o espaço em " $1"
.
EDIT: adicionado um exemplo de letras maiúsculas na primeira letra. Obviamente, caso a primeira letra já esteja em maiúscula - você teria um espaço livre para remover.
text.replace
chamadas de função de preenchimento, eu estive com 2+ argumentos com espaços para leitura demasiado
Non-GoogleChrome
?
Como alternativa, usando lodash :
lodash.startCase(str);
Exemplo:
_.startCase('helloThere');
// ➜ 'Hello There'
O Lodash é uma boa biblioteca para dar atalhos para muitas tarefas diárias do js. Existem muitas outras funções semelhantes de manipulação de strings, como camelCase
, kebabCase
etc.
hello world
, a saída deve ser Hello There
: Nesse caso, o loadash não será útil.
hello world
para Hello World
lodash.com/docs/4.17.15#upperFirst
hello there
para hello world
.
Eu tive um problema semelhante e lidei com isso assim:
stringValue.replace(/([A-Z]+)*([A-Z][a-z])/g, "$1 $2")
Para uma solução mais robusta:
stringValue.replace(/([A-Z]+)/g, " $1").replace(/([A-Z][a-z])/g, " $1")
Entrada:
helloThere
HelloThere
ILoveTheUSA
iLoveTheUSA
Resultado:
hello There
Hello There
I Love The USA
i Love The USA
Exemplo sem efeitos colaterais.
function camel2title(camelCase) {
// no side-effects
return camelCase
// inject space before the upper case letters
.replace(/([A-Z])/g, function(match) {
return " " + match;
})
// replace first char with upper case
.replace(/^./, function(match) {
return match.toUpperCase();
});
}
No ES6
const camel2title = (camelCase) => camelCase
.replace(/([A-Z])/g, (match) => ` ${match}`)
.replace(/^./, (match) => match.toUpperCase());
A melhor string que encontrei para testar as funções camel-case-title-case é esse exemplo ridiculamente absurdo, que testa muitos casos extremos. Que eu saiba, nenhuma das funções postadas anteriormente lida com isso corretamente :
ToGetYourGEDInTimeASongAboutThe26ABCsIsOfTheEssenceButAPersonalIDCardForUser456InRoom26AContainingABC26TimesIsNotAsEasyAs123ForC3POOrR2D2Or2R2D
Isso deve ser convertido para:
Para obter seu GED in time, uma música sobre os 26 ABCs é essencial, mas um cartão de identificação pessoal para o usuário 456 na sala 26A, que contém ABC 26 vezes não é tão fácil quanto 123 para C3PO ou R2D2 ou 2R2D
Se você deseja apenas uma função simples que lide com casos como o descrito acima (e mais casos do que muitas das respostas anteriores), aqui está o que escrevi. Esse código não é particularmente elegante ou rápido, mas é simples, compreensível e funciona.
Um exemplo executável on - line está no jsfiddle , ou você pode visualizar a saída do snippet abaixo no seu console:
// Take a single camel case string and convert it to a string of separate words (with spaces) at the camel-case boundaries.
//
// E.g.:
var examples = [
'ToGetYourGEDInTimeASongAboutThe26ABCsIsOfTheEssenceButAPersonalIDCardForUser456InRoom26AContainingABC26TimesIsNotAsEasyAs123ForC3POOrR2D2Or2R2D',
// --> To Get Your GED In Time A Song About The 26 ABCs Is Of The Essence But A Personal ID Card For User 456 In Room 26A Containing ABC 26 Times Is Not As Easy As 123 For C3PO Or R2D2 Or 2R2D
'helloThere', // --> Hello There
'HelloThere', // --> Hello There
'ILoveTheUSA', // --> I Love The USA
'iLoveTheUSA', // --> I Love The USA
'DBHostCountry', // --> DB Host Country
'SetSlot123ToInput456', // --> Set Slot 123 To Input 456
'ILoveTheUSANetworkInTheUSA', // --> I Love The USA Network In The USA
'Limit_IOC_Duration', // --> Limit IOC Duration
'This_is_a_Test_of_Network123_in_12_days', // --> This Is A Test Of Network 123 In 12 Days
'ASongAboutTheABCsIsFunToSing', // --> A Song About The ABCs Is Fun To Sing
'CFDs', // --> CFDs
'DBSettings', // --> DB Settings
'IWouldLove1Apple', // --> 1 Would Love 1 Apple
'Employee22IsCool', // --> Employee 22 Is Cool
'SubIDIn', // --> Sub ID In
'ConfigureCFDsImmediately', // --> Configure CFDs Immediately
'UseTakerLoginForOnBehalfOfSubIDInOrders', // --> Use Taker Login For On Behalf Of Sub ID In Orders
]
function camelCaseToTitleCase(in_camelCaseString) {
var result = in_camelCaseString // "ToGetYourGEDInTimeASongAboutThe26ABCsIsOfTheEssenceButAPersonalIDCardForUser456InRoom26AContainingABC26TimesIsNotAsEasyAs123ForC3POOrR2D2Or2R2D"
.replace(/([a-z])([A-Z][a-z])/g, "$1 $2") // "To Get YourGEDIn TimeASong About The26ABCs IsOf The Essence ButAPersonalIDCard For User456In Room26AContainingABC26Times IsNot AsEasy As123ForC3POOrR2D2Or2R2D"
.replace(/([A-Z][a-z])([A-Z])/g, "$1 $2") // "To Get YourGEDIn TimeASong About The26ABCs Is Of The Essence ButAPersonalIDCard For User456In Room26AContainingABC26Times Is Not As Easy As123ForC3POOr R2D2Or2R2D"
.replace(/([a-z])([A-Z]+[a-z])/g, "$1 $2") // "To Get Your GEDIn Time ASong About The26ABCs Is Of The Essence But APersonal IDCard For User456In Room26AContainingABC26Times Is Not As Easy As123ForC3POOr R2D2Or2R2D"
.replace(/([A-Z]+)([A-Z][a-z][a-z])/g, "$1 $2") // "To Get Your GEDIn Time A Song About The26ABCs Is Of The Essence But A Personal ID Card For User456In Room26A ContainingABC26Times Is Not As Easy As123ForC3POOr R2D2Or2R2D"
.replace(/([a-z]+)([A-Z0-9]+)/g, "$1 $2") // "To Get Your GEDIn Time A Song About The 26ABCs Is Of The Essence But A Personal ID Card For User 456In Room 26A Containing ABC26Times Is Not As Easy As 123For C3POOr R2D2Or 2R2D"
// Note: the next regex includes a special case to exclude plurals of acronyms, e.g. "ABCs"
.replace(/([A-Z]+)([A-Z][a-rt-z][a-z]*)/g, "$1 $2") // "To Get Your GED In Time A Song About The 26ABCs Is Of The Essence But A Personal ID Card For User 456In Room 26A Containing ABC26Times Is Not As Easy As 123For C3PO Or R2D2Or 2R2D"
.replace(/([0-9])([A-Z][a-z]+)/g, "$1 $2") // "To Get Your GED In Time A Song About The 26ABCs Is Of The Essence But A Personal ID Card For User 456In Room 26A Containing ABC 26Times Is Not As Easy As 123For C3PO Or R2D2Or 2R2D"
// Note: the next two regexes use {2,} instead of + to add space on phrases like Room26A and 26ABCs but not on phrases like R2D2 and C3PO"
.replace(/([A-Z]{2,})([0-9]{2,})/g, "$1 $2") // "To Get Your GED In Time A Song About The 26ABCs Is Of The Essence But A Personal ID Card For User 456 In Room 26A Containing ABC 26 Times Is Not As Easy As 123 For C3PO Or R2D2 Or 2R2D"
.replace(/([0-9]{2,})([A-Z]{2,})/g, "$1 $2") // "To Get Your GED In Time A Song About The 26 ABCs Is Of The Essence But A Personal ID Card For User 456 In Room 26A Containing ABC 26 Times Is Not As Easy As 123 For C3PO Or R2D2 Or 2R2D"
.trim();
// capitalize the first letter
return result.charAt(0).toUpperCase() + result.slice(1);
}
examples.forEach(str => console.log(str, ' --> \n', camelCaseToTitleCase(str)));
Com base em um dos exemplos acima, vim com isso:
const camelToTitle = (camelCase) => camelCase
.replace(/([A-Z])/g, (match) => ` ${match}`)
.replace(/^./, (match) => match.toUpperCase())
.trim()
Funciona para mim porque é usado .trim()
para lidar com o caso em que a primeira letra é maiúscula e você acaba com um espaço extra à esquerda.
Referência: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/Trim
Ok, estou alguns anos atrasado para o jogo, mas tive uma pergunta semelhante e queria criar uma solução de substituição única para cada entrada possível. Devo dar a maior parte do crédito a @ZenMaster neste tópico e a @Benjamin Udink ten Cate neste tópico. Aqui está o código:
var camelEdges = /([A-Z](?=[A-Z][a-z])|[^A-Z](?=[A-Z])|[a-zA-Z](?=[^a-zA-Z]))/g;
var textArray = ["lowercase",
"Class",
"MyClass",
"HTML",
"PDFLoader",
"AString",
"SimpleXMLParser",
"GL11Version",
"99Bottles",
"May5",
"BFG9000"];
var text;
var resultArray = [];
for (var i = 0; i < a.length; i++){
text = a[i];
text = text.replace(camelEdges,'$1 ');
text = text.charAt(0).toUpperCase() + text.slice(1);
resultArray.push(text);
}
Possui três cláusulas, todas usando lookahead para impedir que o mecanismo regex consuma muitos caracteres:
[A-Z](?=[A-Z][a-z])
procura uma letra maiúscula seguida de uma maiúscula e minúscula. Isso é para terminar acrônimos como EUA.[^A-Z](?=[A-Z])
procura por uma letra maiúscula seguida por uma letra maiúscula. Isso termina palavras como myWord e símbolos como 99Bottles.[a-zA-Z](?=[^a-zA-Z])
procura por uma letra seguida por uma não-letra. Isso termina palavras antes de símbolos como BFG9000.Esta pergunta estava no topo dos meus resultados de pesquisa, por isso espero poder poupar outras pessoas algum tempo!
Aqui está a minha versão. Ele adiciona um espaço antes de cada letra em inglês do UpperCase que vem depois de uma letra em minúscula e também coloca a primeira letra em maiúscula, se necessário:
Por exemplo:
thisIsCamelCase -> Este é o caso de camelo
this IsCamelCase -> Este é o caso de camelo
thisIsCamelCase123 -> Este é o caso de camelo123
function camelCaseToTitleCase(camelCase){
if (camelCase == null || camelCase == "") {
return camelCase;
}
camelCase = camelCase.trim();
var newText = "";
for (var i = 0; i < camelCase.length; i++) {
if (/[A-Z]/.test(camelCase[i])
&& i != 0
&& /[a-z]/.test(camelCase[i-1])) {
newText += " ";
}
if (i == 0 && /[a-z]/.test(camelCase[i]))
{
newText += camelCase[i].toUpperCase();
} else {
newText += camelCase[i];
}
}
return newText;
}
Esta implementação leva em maiúsculas e números consecutivos em consideração.
function camelToTitleCase(str) {
return str
.replace(/[0-9]{2,}/g, match => ` ${match} `)
.replace(/[^A-Z0-9][A-Z]/g, match => `${match[0]} ${match[1]}`)
.replace(/[A-Z][A-Z][^A-Z0-9]/g, match => `${match[0]} ${match[1]}${match[2]}`)
.replace(/[ ]{2,}/g, match => ' ')
.replace(/\s./g, match => match.toUpperCase())
.replace(/^./, match => match.toUpperCase())
.trim();
}
// ----------------------------------------------------- //
var testSet = [
'camelCase',
'camelTOPCase',
'aP2PConnection',
'superSimpleExample',
'aGoodIPAddress',
'goodNumber90text',
'bad132Number90text',
];
testSet.forEach(function(item) {
console.log(item, '->', camelToTitleCase(item));
});
Saída esperada:
camelCase -> Camel Case
camelTOPCase -> Camel TOP Case
aP2PConnection -> A P2P Connection
superSimpleExample -> Super Simple Example
aGoodIPAddress -> A Good IP Address
goodNumber90text -> Good Number 90 Text
bad132Number90text -> Bad 132 Number 90 Text
Você pode usar uma função como esta:
function fixStr(str) {
var out = str.replace(/^\s*/, ""); // strip leading spaces
out = out.replace(/^[a-z]|[^\s][A-Z]/g, function(str, offset) {
if (offset == 0) {
return(str.toUpperCase());
} else {
return(str.substr(0,1) + " " + str.substr(1).toUpperCase());
}
});
return(out);
}
"hello World" ==> "Hello World"
"HelloWorld" ==> "Hello World"
"FunInTheSun" ==? "Fun In The Sun"
Código com várias sequências de teste aqui: http://jsfiddle.net/jfriend00/FWLuV/ .
Versão alternativa que mantém os espaços principais aqui: http://jsfiddle.net/jfriend00/Uy2ac/ .
" helloWorld"
, por exemplo.
tente esta biblioteca
http://sugarjs.com/api/String/titleize
'man from the boondocks'.titleize()>"Man from the Boondocks"
'x-men: the last stand'.titleize()>"X Men: The Last Stand"
'TheManWithoutAPast'.titleize()>"The Man Without a Past"
'raiders_of_the_lost_ark'.titleize()>"Raiders of the Lost Ark"
Nenhuma das respostas acima funcionou perfeitamente para mim, então teve que vir com a própria bicicleta:
function camelCaseToTitle(camelCase) {
if (!camelCase) {
return '';
}
var pascalCase = camelCase.charAt(0).toUpperCase() + camelCase.substr(1);
return pascalCase
.replace(/([a-z])([A-Z])/g, '$1 $2')
.replace(/([A-Z])([A-Z][a-z])/g, '$1 $2')
.replace(/([a-z])([0-9])/gi, '$1 $2')
.replace(/([0-9])([a-z])/gi, '$1 $2');
}
Casos de teste:
null => ''
'' => ''
'simpleString' => 'Simple String'
'stringWithABBREVIATIONInside => 'String With ABBREVIATION Inside'
'stringWithNumber123' => 'String With Number 123'
'complexExampleWith123ABBR890Etc' => 'Complex Example With 123 ABBR 890 Etc'
Isso funciona para mim, verifique isso
CamelcaseToWord ("MyName"); // retorna Meu nome
function CamelcaseToWord(string){
return string.replace(/([A-Z]+)/g, " $1").replace(/([A-Z][a-z])/g, " $1");
}
string.replace(/([A-Z]+)/g, " $1").replace(/([A-Z][a-z])/g, "$1");
Eu acho que isso pode ser feito apenas com o reg exp /([a-z]|[A-Z]+)([A-Z])/g
e substituição "$1 $2"
.
ILoveTheUSADope -> Eu amo o narcótico dos EUA
QWERTY
ele retorna QWERT Y
.
Se você lida com o Capital Camel Case, esse trecho pode ajudá-lo, mas também contém algumas especificações, para que você possa ter certeza de que ele corresponde ao seu caso.
export const fromCamelCaseToSentence = (word) =>
word
.replace(/([A-Z][a-z]+)/g, ' $1')
.replace(/([A-Z]{2,})/g, ' $1')
.replace(/\s{2,}/g, ' ')
.trim();
E especificações:
describe('fromCamelCaseToSentence', () => {
test('does not fall with a single word', () => {
expect(fromCamelCaseToSentence('Approved')).toContain('Approved')
expect(fromCamelCaseToSentence('MDA')).toContain('MDA')
})
test('does not fall with an empty string', () => {
expect(fromCamelCaseToSentence('')).toContain('')
})
test('returns the separated by space words', () => {
expect(fromCamelCaseToSentence('NotApprovedStatus')).toContain('Not Approved Status')
expect(fromCamelCaseToSentence('GDBState')).toContain('GDB State')
expect(fromCamelCaseToSentence('StatusDGG')).toContain('Status DGG')
})
})
Não tentei a resposta de todos, mas as poucas soluções com as quais eu trabalhei não atendiam a todos os meus requisitos.
Consegui inventar algo que fez ...
export const jsObjToCSSString = (o={}) =>
Object.keys(o)
.map(key => ({ key, value: o[key] }))
.map(({key, value}) =>
({
key: key.replace( /([A-Z])/g, "-$1").toLowerCase(),
value
})
)
.reduce(
(css, {key, value}) =>
`${css} ${key}: ${value}; `.trim(),
'')
Abaixo está o link que demonstra a sequência de caracteres de camelo para sentença usando regex.
myCamelCaseSTRINGToSPLITDemo
my Camel Case STRING To SPLIT Demo
Este é o regex para conversão de maiúsculas e minúsculas em texto de frase
(?=[A-Z][a-z])|([A-Z]+)([A-Z][a-rt-z][a-z]\*)
com $1 $2
como subscrição.
Mais uma solução baseada em RegEx.
respace(str) {
const regex = /([A-Z])(?=[A-Z][a-z])|([a-z])(?=[A-Z])/g;
return str.replace(regex, '$& ');
}
O RegEx acima consiste em duas partes semelhantes separadas pelo operador OR . A primeira metade:
([A-Z])
- corresponde a letras maiúsculas ...(?=[A-Z][a-z])
- seguido por uma sequência de letras maiúsculas e minúsculas.Quando aplicado à sequência FOo , corresponde efetivamente à sua letra F.
Ou o segundo cenário:
([a-z])
- corresponde a letras minúsculas ...(?=[A-Z])
- seguido por uma letra maiúscula.Quando aplicado à sequência barFoo , corresponde efetivamente à sua letra r .
Quando todos os candidatos a substituição foram encontrados, a última coisa a fazer é substituí-los pela mesma letra, mas com um caractere de espaço adicional. Para isso, podemos usar '$& '
como um substituto, e ele será resolvido para uma substring correspondente, seguida por um caractere de espaço.
const regex = /([A-Z])(?=[A-Z][a-z])|([a-z])(?=[A-Z])/g
const testWords = ['ACoolExample', 'fooBar', 'INAndOUT', 'QWERTY', 'fooBBar']
testWords.map(w => w.replace(regex, '$& '))
->(5) ["A Cool Example", "foo Bar", "IN And OUT", "QWERTY", "foo B Bar"]
Adicionando mais uma solução ES6 que eu mais gostei depois de não estar feliz com algumas reflexões acima.
https://codepen.io/902Labs/pen/mxdxRv?editors=0010#0
const camelize = (str) => str
.split(' ')
.map(([first, ...theRest]) => (
`${first.toUpperCase()}${theRest.join('').toLowerCase()}`)
)
.join(' ');