文字列を特定の文字で区切りながら分割するには?

次のような文字列があります。

'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.
解説 (0)

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];
解説 (2)

ECMAScript6 ES6 によると、クリーンな方法は配列を破壊することです。

<! -- スニペットを開始します。 js hide. false console. true babel. true --&gt.

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
解説 (2)

一番簡単な方法ではないにしても、これはこれでいいんじゃないかな。

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
解説 (2)

JavaScriptのsubstrsplitを参考にしてみてはいかがでしょうか。

解説 (0)

まあ、一番簡単な方法は、次のようなものでしょう。

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

スプリッターが見つかった場合は、**のみ

割り勘

他の場合は 同じ文字列 を返します。

のようになります。 関数 SplitTheString(ResultStr) { のようになっています。 if (ResultStr != null) { を使用しています。 var SplitChars = '~'. となります。 if (ResultStr.indexOf(SplitChars) >= 0) { &gt.のようになります。 var DtlStr = ResultStr.split(SplitChars). &gt. var name = DtlStr[0]. となっています。 var street = DtlStr[1].

} } }。 }。

解説 (0)

テキストを分割するには split を用いることができる。

別の方法として、以下のように match を使うこともできます。

<! -- スニペットを開始します。 js hide. false --&gt.

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

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

<! -- end snippet --&gt.

正規表現 [^~]+~ を除くすべての文字にマッチし、マッチした文字を配列で返します。 そして、そこからマッチした文字を抽出することができます。

解説 (2)

みたいな感じで。

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

おそらく最も簡単になるだろう

解説 (1)

Zachはこれが正解だった... 彼の方法を使えば、一見"多次元&quot. 配列を作ることもできます。 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(",");
解説 (0)

この string.split("~")[0]; は物事を成し遂げる。

ソースコードを参照してください。 String.prototype.split()][1


**カレーと関数合成を使った別の機能アプローチ。

ということで、まずは分割関数ですね。 この "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 関数を構築することができる。 reduceを用いたcompose`関数の構築。

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

そして、これを使って splitByTildefirst 関数を作成しています。

const getName = compose(first, splitByTilde);

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

[1]: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/split

解説 (0)

Try in Plain Javascript

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

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

このコードを使用してください

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

}
解説 (0)

カンマの分割の質問はこの質問と重複しているので、ここに追加します。

ある文字で分割したい場合や、その文字に続く余分な空白を扱いたい場合、カンマでよく発生するような場合は、replaceを使ってからsplitを使うことができます。

var items = string.replace(/,\s+/, ",").split(&#39;,&#39;)
解説 (0)

JavaScript. 文字列を配列に変換する JavaScriptの分割

<! -- スニペットを開始します。 js hide. false console. true babel. false --&gt.

    var str = "This-javascript-tutorial-string-split-method-examples-tutsmake."

    var result = str.split('-'); 

    console.log(result);

    document.getElementById("show").innerHTML = result; 


How do you split a string, breaking at a particular character in javascript?



<p id="show"></p> 


<! -- end snippet --&gt.

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

解説 (0)