私は誰かがRubyでこれを行ったコードを読みました:
puts ('A'..'Z').to_a.join(',')
出力:
A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P,Q,R,S,T,U,V,W,X,Y,Z
Javascript
これを同じように簡単に行えるようにする何かがありますか?そうでない場合、同様のことを可能にするノードモジュールはありますか?
私は誰かがRubyでこれを行ったコードを読みました:
puts ('A'..'Z').to_a.join(',')
出力:
A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P,Q,R,S,T,U,V,W,X,Y,Z
Javascript
これを同じように簡単に行えるようにする何かがありますか?そうでない場合、同様のことを可能にするノードモジュールはありますか?
ES6を使用している場合は、Array.from()を使用して、範囲の長さの配列のようなオブジェクトを渡すことでシーケンスを生成できます。また、2番目の引数としてmap関数を使用して、 String.fromCharCode()を使用した文字への範囲:
Array.from({ length: 26 }, (_, i) => String.fromCharCode('A'.charCodeAt(0) + i));
配列コンストラクター(注:ES6では、コンストラクターを関数呼び出しまたはnew
演算子のいずれかで呼び出すことができます)を使用して、目的のデフォルトの長さの配列を初期化し、Array.fill()を使用して配列を埋めてから、マップすることもできます。
Array(26).fill().map((_, i) => String.fromCharCode('A'.charCodeAt(0) + i));
スプレッド演算子でも同じことができます。
[...Array(26)].map((_, i) => String.fromCharCode('A'.charCodeAt(0) + i));
上記の3つの例では、AからZまでの文字を含む配列が返されます。カスタム範囲の場合、長さと開始文字を調整できます。
ES6をサポートしていないブラウザーの場合は、babel-polyfillまたはcore-js polyfill(core-js / fn / array / from)を使用できます。
ES5をターゲットにしている場合は、 @wiresによるArray.applyソリューションをお勧めします。これはこれと非常によく似ています。
最後に、Underscore / LodashとRamdaにはrange()関数があります。
_.range('A'.charCodeAt(0), 'Z'.charCodeAt(0) + 1).map(i => String.fromCharCode(i));
Javascriptにはその機能がネイティブにありません。以下に、それを解決する方法の例をいくつか示します。
通常の機能、ベースプレーンからの任意の文字(代理ペアのチェックなし)
function range(start,stop) {
var result=[];
for (var idx=start.charCodeAt(0),end=stop.charCodeAt(0); idx <=end; ++idx){
result.push(String.fromCharCode(idx));
}
return result;
};
range('A','Z').join();
上記と同じですが、配列プロトタイプに追加された関数として、したがってすべての配列で使用できます。
Array.prototype.add_range = function(start,stop) {
for (var idx=start.charCodeAt(0),end=stop.charCodeAt(0); idx <=end; ++idx){
this.push(String.fromCharCode(idx));
}
return this;
};
[].add_range('A','Z').join();
事前に選択された文字からの範囲。上記の関数よりも高速で、alphanum_range('A','z')
AZとazを意味するために使用できます。
var alphanum_range = (function() {
var data = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789'.split('');
return function (start,stop) {
start = data.indexOf(start);
stop = data.indexOf(stop);
return (!~start || !~stop) ? null : data.slice(start,stop+1);
};
})();
alphanum_range('A','Z').join();
または、ASCII範囲の任意の文字。キャッシュされた配列を使用することにより、毎回配列を構築する関数よりも高速になります。
var ascii_range = (function() {
var data = [];
while (data.length < 128) data.push(String.fromCharCode(data.length));
return function (start,stop) {
start = start.charCodeAt(0);
stop = stop.charCodeAt(0);
return (start < 0 || start > 127 || stop < 0 || stop > 127) ? null : data.slice(start,stop+1);
};
})();
ascii_range('A','Z').join();
var chars = [].concat.apply([], Array(26))
.map(function(_, i) { return String.fromCharCode(i+65); })
.join();
関数は、.map
さまざまな文字セットに使用できる関数発生器である可能性があります。
function charRange(start) {
var base = start.charCodeAt(0);
return function(_, i) { return String.fromCharCode(i + base); };
}
また、「完全な」配列ヘルパーを作成することもできます。
function fullArray(len) { return [].concat.apply([], Array(len)); }
次に、このように使用します。
var chars = fullArray(26).map(charRange("A"))
.join();
TL; DR
// ['a', .. , 'z']
Array.apply(null, {length: 26})
.map(function (x,i) { return String.fromCharCode(97 + i) });
あるいは
function range(first, last) {
var a = first.charCodeAt(0)
var b = last.charCodeAt(0) + 1
return Array.apply(null, {length: Math.abs(b - a)})
.map(function (x,i) { return String.fromCharCode(Math.min(a, b) + i) });
}
range('K','M') // => ['K','L','M']
range('$','z') // => "$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz"
[0 .. 25]
これは、機能的な方法で最も明確に表現できると思います['a' .. 'z']
。
fromCharCode(n)
数値を文字列に変換するために使用できます。文字に対応する数値を見つけるには、その逆関数が必要ですtoCharCode(s)
。
var toCharCode = function(s){ return s.charCodeAt(0) } // 'a' => 97, 'b' => 98, ..
その後、残りは簡単です:
Array.apply(null, {length: 26})
.map(function (x,i) { return String.fromCharCode(97 + i) });
26個の未定義の配列を作成します[undefined, ... , undefined]
。次に、各値のmap
インデックスを==に設定します(大文字の場合はで始まります)。i
97 + i
'a'.charCodeAt(0) + i
'A' => 65
この最初の行には説明が必要な場合があります。Array(1,2,3)
私たちが効果的に行っていることは==と同じ[1,2,3]
です。実際の配列をに渡す代わりに、配列のように(プロパティを持つ)apply
何かを渡します。length
これにより、が呼び出されArray(undefined, .. , undefined)
ます。
詳細については
apply
、
「一般的な配列のようなオブジェクト」
を参照してください。
同様の質問については、kannebecからの回答をご覧ください。
JavaScriptには、提供された境界に基づいて配列を生成する「range()」のようなメソッドがありますか?
独自の関数を追加したくないが、1行で追加したい場合:
var abc =
(function(){var output = []; for(var i='A'.charCodeAt(0); i <= 'Z'.charCodeAt(0); i++)
output.push(String.fromCharCode(i)); return output;})().join(',');
CoffeeScriptはjavascriptにコンパイルされ、数値範囲があります。
(String.fromCharCode(x+64) for x in [1..26]).join(",")
これは、coffeescript.orgサイトにあるこのスクリプトへのリンクです。コンパイル先のJavaScriptを確認し、ブラウザでライブで実行できます。
(はい、Node.jsにcoffeescriptを使用できます)
少し異なるアプローチ
String.fromCharCode(..." ".repeat(26).split("").map((e,i)=>i+'A'.charCodeAt()))
プリント
"ABCDEFGHIJKLMNOPQRSTUVWXYZ"
多分この関数はあなたを助けるでしょう。
function range ( low, high, step ) { // Create an array containing a range of elements
//
// + original by: _argos
var matrix = [];
var inival, endval, plus;
var walker = step || 1;
var chars = false;
if ( !isNaN ( low ) && !isNaN ( high ) ) {
inival = low;
endval = high;
} else if ( isNaN ( low ) && isNaN ( high ) ) {
chars = true;
inival = low.charCodeAt ( 0 );
endval = high.charCodeAt ( 0 );
} else {
inival = ( isNaN ( low ) ? 0 : low );
endval = ( isNaN ( high ) ? 0 : high );
}
plus = ( ( inival > endval ) ? false : true );
if ( plus ) {
while ( inival <= endval ) {
matrix.push ( ( ( chars ) ? String.fromCharCode ( inival ) : inival ) );
inival += walker;
}
} else {
while ( inival >= endval ) {
matrix.push ( ( ( chars ) ? String.fromCharCode ( inival ) : inival ) );
inival -= walker;
}
}
return matrix;
}
console.log(range('A','Z'))
// ["A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M", "N", "O", "P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y", "Z"]
これは私のものではなく、http://javascript.ru/php/rangeから取得したものです。
いいえ、JavaScriptには組み込みのRangeオブジェクトはありません。抽象範囲を作成する関数を作成してからto_a
、同等のメソッドを追加する必要があります。
楽しみのために、中間の文字列を使用せずに、正確な出力を取得する別の方法を次に示します。
function commaRange(startChar,endChar){
var c=','.charCodeAt(0);
for (var a=[],i=startChar.charCodeAt(0),e=endChar.charCodeAt(0);i<=e;++i){
a.push(i); a.push(c);
}
a.pop();
return String.fromCharCode.apply(String,a);
}
console.log(commaRange('A','J')); // "A,B,C,D,E,F,G,H,I,J"
Node.jsには、Lazyモジュールがあります。
https://stackoverflow.com/a/64599169/8784402
const charList = (a,z,d=1)=>(a=a.charCodeAt(),z=z.charCodeAt(),[...Array(Math.floor((z-a)/d)+1)].map((_,i)=>String.fromCharCode(a+i*d)));
console.log("from A to G", charList('A', 'G'));
console.log("from A to Z with step/delta of 2", charList('A', 'Z', 2));
console.log("reverse order from Z to P", charList('Z', 'P', -1));
console.log("from 0 to 5", charList('0', '5', 1));
console.log("from 9 to 5", charList('9', '5', -1));
console.log("from 0 to 8 with step 2", charList('0', '8', 2));
console.log("from α to ω", charList('α', 'ω'));
console.log("Hindi characters from क to ह", charList('क', 'ह'));
console.log("Russian characters from А to Я", charList('А', 'Я'));
const charList = (p: string, q: string, d = 1) => {
const a = p.charCodeAt(0),
z = q.charCodeAt(0);
return [...Array(Math.floor((z - a) / d) + 1)].map((_, i) =>
String.fromCharCode(a + i * d)
);
};
function range(r, x) {
var c1 = r.charCodeAt(0)+1, c2 = r.charCodeAt(3), s = r[0];
if(c1 && c2)while (c1 <= c2) s += (x || "") + String.fromCharCode(c1++);
return s;
}
range("A--S", ",");
var range = [];
for(var i = 65; i < 91; i++)
{
range.push(String.fromCharCode(i));
}
range = range.join(',');
範囲azを与えますが、私もいくつかの関数オプションが好きです。