内容简介:The C# Language Integrated Queries ported for Javascript for amazing performanceArray functions in Javascript create a new array for each operation, which is terribly wasteful. Using iterators and generator functions and objects, we can limit the operation
LInQer v1.0.0
The C# Language Integrated Queries ported for Javascript for amazing performance
Array functions in Javascript create a new array for each operation, which is terribly wasteful. Using iterators and generator functions and objects, we can limit the operations to the items in the array that interest us, not all of them.
More details on the blog post for it: https://siderite.dev/blog/linq-in-javascript-linqer/ . Leave comments there or add Issues here in order to get features or bug fixes or whatever.
Find it hosted on GitHub Pages and use it freely in your projects at:
- https://siderite.github.io/LInQer/LInQer.min.js
- https://siderite.github.io/LInQer/LInQer.slim.min.js
- https://siderite.github.io/LInQer/LInQer.extra.min.js .
Usage
Reference Linqer.slim.js for the basic methods:
- the static from, empty, range, repeat
- concat
- count
- distinct
- elementAt and elementAtOrDefault
- first and firstOrDefault
- last and lastOrDefault
- min, max, stats (min, max and count)
- select
- skip and take
- sum and sumAndCount (sum and count)
- toArray
- toList - similar to toArray, but returns an Enumerable (itself if already seekable)
- where
Reference Linqer.js for all of the original Enumerable methods, the ones in slim plus:
- aggregate
- all
- any
- append
- average
- asEnumerable
- cast
- contains
- defaultIfEmpty - throws not implemented
- except
- intersect
- longCount
- ofType
- prepend
- reverse
- selectMany
- sequenceEqual
- single
- singleOrDefault
- skipLast
- skipWhile
- takeLast
- takeWhile
- toDictionary - throws not implemented
- toMap
- toObject
- toHashSet - throws not implemented
- toSet
- toList - throws not implemented
- union
- zip
Reference Linqer.extra.js (needs Linqer.js) for some additional methods:
- shuffle - randomizes the enumerable
- randomSample - implements random reservoir sampling of k items
- distinctByHash - distinct based on a hashing function, not a comparer - faster
- exceptByHash - except based on a hashing function, not a comparer - faster
- intersectByHash - intersect based on a hashing function, not a comparer - faster
- binarySearch - find the index of a value in a sorted enumerable by binary search
- lag - joins each item of the enumerable with previous items from the same enumerable
- lead - joins each item of the enumerable with next items from the same enumerable
- padStart - pad enumerable at the start to a minimum length
- padEnd - pad enumerable at the end to a minimum length
const source = ... an array or a generator function or anything that is iterable... ;
const enumerable = Linqer.Enumerable.from(source); // now you can both iterate and use LINQ like functions
const result = enumerable
.where(item=>!!item.value) // like filter
.select(item=>{ value: item.value, key: item.name }) // like map
.groupBy(item=>item.key)
.where(g=>g.length>10)
.selectMany()
.skip(15)
.take(5)
.toArray();
Original Enumerable
The original C# class can be found here: https://docs.microsoft.com/en-us/dotnet/api/system.linq.enumerable .
Building the solution
The source files have been moved to Typescript. Run build.bat to create the js and map files.
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
高性能Python
(美)戈雷利克、(英)欧日沃尔德 / 东南大学出版社 / 2015-2
你的Python代码也许运行正确,但是你需要运行得更快速。通过探讨隐藏在设计备选方案中的基础理论,戈雷利克和欧日沃尔德编著的《高性能Python》将帮助你更深入地理解Python的实现。你将了解如何定位性能瓶颈,从而显著提升高数据流量程序中的代码执行效率。 你该如何利用多核架构和集群?或者你该如何搭建一个可以自由伸缩而不会影响可靠性的系统?有经验的Python程序员将会学习到这类问题的具体解......一起来看看 《高性能Python》 这本书的介绍吧!