Как мне разделить строку, обрываясь на определенном символе?

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

  •  01-07-2019
  •  | 
  •  

Вопрос

У меня есть эта строка

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

Используя JavaScript, каков самый быстрый способ разобрать это на

var name = "john smith";
var street= "123 Street";
//etc...
Это было полезно?

Решение

С помощью JavaScript String.prototype.split функция:

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.

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

Вам не нужен 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];

Согласно 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

У вас могут быть дополнительные элементы во входной строке.В этом случае вы можете использовать оператор rest, чтобы получить массив для остальных или просто проигнорировать их:

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!

Несмотря на то, что это не самый простой способ, вы могли бы сделать это:

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

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

ну, проще всего было бы что-то вроде:

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

Если Разделитель найден тогда только

Раздели его

иначе верните та же строка

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];
        }
    }
}

Что -то вроде:

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

Вероятно, это будет проще всего

Вы можете использовать split чтобы разделить текст.

В качестве альтернативы вы также можете использовать match как следует

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

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

Регулярное выражение [^~]+ будет соответствовать всем символам, за исключением ~ и возвращает совпадения в виде массива.Затем вы можете извлечь из него спички.

В этом Зак был прав..используя его метод, вы также могли бы создать, казалось бы, "многомерный" массив..Я создал краткий пример в 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(",");

Это string.split("~")[0]; доводит дела до конца.

Источник: Строка.прототип.сплит()


Другой функциональный подход с использованием карри и функциональной композиции.

Итак, первым делом будет функция разделения.Мы хотим сделать это "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"

Поскольку вопрос о разделении на запятые дублируется к этому вопросу, добавляю это здесь.

Если вы хотите разделить символ, а также обработать дополнительные пробелы, которые могут следовать за этим символом, что часто случается с запятыми, вы можете использовать replace тогда split, вот так:

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

Попробуйте использовать обычный Javascript

 //basic url=http://localhost:58227/ExternalApproval.html?Status=1

 var ar= [url,statu] = window.location.href.split("=");

Используйте этот код --

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

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