listorange

List array to Range

Usage no npm install needed!

<script type="module">
  import listorange from 'https://cdn.skypack.dev/listorange';
</script>

README

listorange

listorange is a non-blocking function, that converts array of numbers in to compact range array or string description. For example:

[1,2,3,4,5,6,7,8] -> "1-8" || [[1,8]]
[1,3,4,5,6,7,8] -> "1,3-8"
[1,3,4,5,6,7,8,10,11,12] -> "1,3-8,10-12"
[1,2,3] -> "1-3"
[1,2] -> "1,2"
[1,2,4] -> "1,2,4"
[1,2,4,5,6] -> "1,2,4-6" || [[1,2],[4,6]]
[1,2,3,7,8,9,15,17,19,20,21] -> "1-3,7-9,15,17,19-21"
[1,2,3,4,5,6,100,1091,1999,2000,2001,2002] -> "1-6,100,1091,1999-2002" || [[1,6],[100],[1091],[1999,2002]]
[1] -> "1"
[1,3,5,7,9,11] -> "1,3,5,7,9,11"
[5,6,19,5,5,3,16,4,19,17] -> [[3,6],[16,17],[19]]

Install

npm install listorange --save

Usage

Declaration

listorange(array, getString, sort, step);

Arguments

array (Array): List array of numbers.
getString (Boolean): Return result as string range. Default is true.
sort (Boolean): Sort array before parsing. Default is false. Uses non-blocking quicksort module qqsort.
step (Number): Max iterate count to separate iteration tasks to nextTick. Usefull for non-blocking. Optimal and default value is 10000.

Returns

(Promise): Returns promise. Callback in .then receives (result) as argument. The result can be a string or an array depending on getString argument passed to listorange function.

Examples

const listorange = require('listorange');

listorange([1,2,3,4,5,6,7,8]).then(str=>{
    console.log(str);
});
// result: "1-8"

listorange([1,2,3,4,5,6,7,8], false).then(str=>{
    console.log(str);
});
// result: [[1,8]]

listorange([5,6,19,5,5,3,16,4,19,17], true, true).then(str=>{
    console.log(str);
});
// result: "3-6,16,17,19"

listorange([5,6,19,5,5,3,16,4,19,17], true, true).then(str=>{
    console.log(str);
});
// result: [[3,6],[16,17],[19]]

Tests

npm test

License

MIT