Як я розбиваю струну, розриваючись на конкретного символу?


533

У мене є ця струна

'john smith~123 Street~Apt 4~New York~NY~12345'

Використовуючи JavaScript, це найшвидший спосіб проаналізувати це

var name = "john smith";
var street= "123 Street";
//etc...

Відповіді:


845

За допомогою String.prototype.splitфункції JavaScript :

var input = 'john smith~123 Street~Apt 4~New York~NY~12345';

var fields = input.split('~');

var name = fields[0];
var street = fields[1];
// etc.

51

Вам не потрібен jQuery.

var s = 'john smith~123 Street~Apt 4~New York~NY~12345';
var fields = s.split(/~/);
var name = fields[0];
var street = fields[1];

53
Вам не потрібно додавати регулярну форму в цю просту заміну. Це зробить це лише повільніше, якщо що. Ви можете змінити його на лапки для простої заміни рядка.
Аніш Гупта

47

Відповідно до ECMAScript6 ES6, чистий спосіб знищення масивів:

const input = 'john smith~123 Street~Apt 4~New York~NY~12345';

const [name, street, unit, city, state, zip] = input.split('~');

console.log(name); // john smith
console.log(street); // 123 Street
console.log(unit); // Apt 4
console.log(city); // New York
console.log(state); // NY
console.log(zip); // 12345

У рядку введення можуть бути додаткові елементи. У цьому випадку ви можете використовувати оператор відпочинку, щоб отримати масив для решти або просто проігнорувати їх:

const input = 'john smith~123 Street~Apt 4~New York~NY~12345';

const [name, street, ...others] = input.split('~');

console.log(name); // john smith
console.log(street); // 123 Street
console.log(others); // ["Apt 4", "New York", "NY", "12345"]

Я вважав, що для значень використовується посилання лише для читання, і я використовував constдекларацію.

Насолоджуйтесь ES6!


6
Ви також можете пропустити предмет:const [name, , unit, ...others] = ...
Sallar

16

Хоча це не найпростіший спосіб, ви могли це зробити:

var addressString = "~john smith~123 Street~Apt 4~New York~NY~12345~",
    keys = "name address1 address2 city state zipcode".split(" "),
    address = {};

// clean up the string with the first replace
// "abuse" the second replace to map the keys to the matches
addressString.replace(/^~|~$/g).replace(/[^~]+/g, function(match){
    address[ keys.unshift() ] = match;
});

// address will contain the mapped result
address = {
    address1: "123 Street"
    address2: "Apt 4"
    city: "New York"
    name: "john smith"
    state: "NY"
    zipcode: "12345"
}

Оновлення для ES2015 з використанням деструктуризації

const [address1, address2, city, name, state, zipcode] = addressString.match(/[^~]+/g);

// The variables defined above now contain the appropriate information:

console.log(address1, address2, city, name, state, zipcode);
// -> john smith 123 Street Apt 4 New York NY 12345

4
спочатку у нас є рядок, відокремлена знаками '~' та масивом keys. Друга функція заміни використовується [^~]+для узгодження кожної різної частини (наприклад, "123 Street", "Apt 4" тощо) та викликає функцію для кожної частини, передаючи її як аргумент. При кожному запуску функція бере перший ключ з масиву ключів (також видаляючи його за допомогою Array.unshift) і призначає адресу та об’єкту адресу.
ewino


5

ну, найпростішим способом було б щось на зразок:

var address = theEncodedString.split(/~/)
var name = address[0], street = address[1]

5

Якщо сплітер знайдений то тільки

Розділіть його

ще повернути ту саму рядок

function SplitTheString(ResultStr) {
    if (ResultStr != null) {
        var SplitChars = '~';
        if (ResultStr.indexOf(SplitChars) >= 0) {
            var DtlStr = ResultStr.split(SplitChars);
            var name  = DtlStr[0];
            var street = DtlStr[1];
        }
    }
}

4

Щось на зразок:

var divided = str.split("/~/");
var name=divided[0];
var street = divided[1];

Напевно, буде найпростіше


2
Ні, ти хочеш split("~")або split(/~/)не, але ні split("/~/"). Останній би лише розколовся, "John/~/Smith"а ні "John~Smith".
Ендрю Віллемс

4

Ви можете використовувати splitдля розділення тексту.

В якості альтернативи ви також можете використовувати matchнаступне

var str = 'john smith~123 Street~Apt 4~New York~NY~12345';
matches = str.match(/[^~]+/g);

console.log(matches);
document.write(matches);

Регекс [^~]+відповідатиме всім символам, за винятком, ~і повертає збіги у масиві. Потім можна витягнути з нього сірники.


1
Це працювало для мене! str.split();не працював у Firefox, але це працювало і в Chrome, і в Firefox.
Сандіп


2

Зак мав це право. Використовуючи його метод, ви також можете зробити начебто "багатовимірний" масив .. Я створив швидкий приклад на JSFiddle http://jsfiddle.net/LcnvJ/2/

// array[0][0] will produce brian
// array[0][1] will produce james

// array[1][0] will produce kevin
// array[1][1] will produce haley

var array = [];
    array[0] = "brian,james,doug".split(",");
    array[1] = "kevin,haley,steph".split(",");

2

JavaScript: Перетворити рядок в масив JavaScript Спліт

    var str = "This-javascript-tutorial-string-split-method-examples-tutsmake."
 
    var result = str.split('-'); 
     
    console.log(result);
     
    document.getElementById("show").innerHTML = result; 
<html>
<head>
<title>How do you split a string, breaking at a particular character in javascript?</title>
</head>
<body>
 
<p id="show"></p> 
 
</body>
</html>

https://www.tutsmake.com/javascript-convert-string-to-array-javascript/


1

Це string.split("~")[0];робить справи.

джерело: String.prototype.split ()


Ще один функціональний підхід із використанням складу каррі та функції.

Тому першим ділом була б функція спліт. Ми хочемо зробити це "john smith~123 Street~Apt 4~New York~NY~12345"в цьому["john smith", "123 Street", "Apt 4", "New York", "NY", "12345"]

const split = (separator) => (text) => text.split(separator);
const splitByTilde = split('~');

Тож тепер ми можемо використовувати нашу спеціалізовану splitByTildeфункцію. Приклад:

splitByTilde("john smith~123 Street~Apt 4~New York~NY~12345") // ["john smith", "123 Street", "Apt 4", "New York", "NY", "12345"]

Для отримання першого елемента ми можемо використовувати list[0]оператор. Давайте побудуємо firstфункцію:

const first = (list) => list[0];

Алгоритм: розділити на двокрапку і потім отримати перший елемент заданого списку. Тож ми можемо скласти ці функції для побудови нашої кінцевої getNameфункції. Побудова composeфункції за допомогою reduce:

const compose = (...fns) => (value) => fns.reduceRight((acc, fn) => fn(acc), value);

А тепер використовуємо його для складання splitByTildeта firstфункціонування.

const getName = compose(first, splitByTilde);

let string = 'john smith~123 Street~Apt 4~New York~NY~12345';
getName(string); // "john smith"


0

Оскільки роздвоєння на коми запитання дублюється на це питання, додаючи це тут.

Якщо ви хочете розділити на персонаж, а також обробити додатковий пробіл, який може слідувати за цим символом, що часто трапляється з комами, ви можете використовувати replaceтоді split, як це:

var items = string.replace(/,\s+/, ",").split(',')

-1

Використовуйте цей код -

function myFunction() {
var str = "How are you doing today?";
var res = str.split("/");

}
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.