Question

J'ai cette chaîne

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

À l'aide de JavaScript, quel est le moyen le plus rapide de l'analyser dans

var name = "john smith";
var street= "123 Street";
//etc...
Était-ce utile?

La solution

Avec les String.prototype de JavaScript Fonction .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.

Autres conseils

Vous n'avez pas besoin de 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];

Selon ECMAScript6 ES6 , la méthode propre consiste à détruire les tableaux:

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

Vous pouvez avoir des éléments supplémentaires dans la chaîne d'entrée. Dans ce cas, vous pouvez utiliser l'opérateur rest pour obtenir un tableau pour le reste ou simplement les ignorer:

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"]

J'ai supposé une référence en lecture seule pour les valeurs et utilisé la déclaration const .

Profitez de l'ES6!

Même si ce n'est pas la façon la plus simple, vous pouvez le faire:

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"
}

Mise à jour pour ES2015, à l'aide de la déstructuration

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

Vous voudrez vous pencher sur sous ou split , car ce n’est pas vraiment une tâche adaptée à jQuery.

Eh bien, le moyen le plus simple serait quelque chose comme:

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

Si Spliter est trouvé , alors seulement

Divisez-le

sinon renvoie la même chaîne

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

Quelque chose comme:

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

Est-ce que ça va probablement être le plus facile

Vous pouvez utiliser split pour scinder le texte.

Vous pouvez également utiliser match comme suit

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

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

La regex [^ ~] + correspondra à tous les caractères sauf ~ et renverra les correspondances dans un tableau. Vous pouvez ensuite en extraire les correspondances.

Zach avait ce droit. en utilisant sa méthode, vous pouvez également créer une apparence apparemment "multi-dimensionnelle". array .. J'ai créé un exemple rapide sur 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(",");

Ce string.split ("~") [0]; permet de faire avancer les choses.

source: String.prototype.split ()

Autre approche fonctionnelle utilisant le curry et la composition fonctionnelle.

Donc, la première chose serait la fonction split. Nous voulons que ce "john smith ~ 123 Street ~ appt 4 ~ New York ~ NY ~ 12345" en ce code ["John Smith", "123 Street", "quot". Apt 4 "," New York "," NY "," 12345 "]

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

Nous pouvons maintenant utiliser notre fonction spécialisée splitByTilde . Exemple:

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

Pour obtenir le premier élément, nous pouvons utiliser l'opérateur list [0] . Construisons une première fonction:

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

L'algorithme est le suivant: scindé par les deux points, puis récupère le premier élément de la liste donnée. Nous pouvons donc composer ces fonctions pour construire notre dernière fonction getName . Construire une fonction composer avec réduire :

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

Et maintenant, utilisez-le pour composer les fonctions splitByTilde et en premier .

const getName = compose(first, splitByTilde);

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

La question de la division par des virgules étant dupliquée pour cette question, ajoutez-la ici.

Si vous souhaitez séparer un caractère et gérer également les espaces supplémentaires pouvant suivre ce caractère, ce qui arrive souvent avec des virgules, vous pouvez utiliser remplacer , puis fractionner , comme ceci:

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

Essayez en Javascript simple

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

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

Utilisez ce code -

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

}
Licencié sous: CC-BY-SA avec attribution
Non affilié à StackOverflow
scroll top