1.0.1 • Published 2 years ago

csv-row-limit v1.0.1

Weekly downloads
-
License
MIT
Repository
github
Last release
2 years ago

Csv Row Limit

简体中文

A lightweight, fast, and pure-native CSV row count limiting library.

  • Tiny. Very small package size, no dependencies, core code is less than 100 lines.
  • Fast. 5-9 times faster than fast-csv (data based on benchmark tests below).
  • Easy to use. Encapsulated using async/await, external users only need to perceive one function.
  • Stable. Unit and benchmark tests are performed every time the package is published to ensure package stability.

🚀 Benchmark

$ yarn benchmark
# Get the first 100 rows out of 1000 rows
csv-row-limit limit 100 from 1000 lines      7369 ops/sec
fast-csv limit 100 from 1000 lines            796 ops/sec

# Get the first 10,000 rows out of 100,000 rows
csv-row-limit limit 1w from 10w lines         397 ops/sec
fast-csv limit 1w from 10w lines               61 ops/sec

# Get the first 100,000 rows out of 1,000,000 rows
csv-row-limit limit 10w from 100w lines        34 ops/sec
fast-csv limit 10w from 100w lines              6 ops/sec

Test configuration: MacBook Air (M2, 2022), macOS Monterey 12.5.1, Node.js 16.19.0.

🛠 Installation

yarn add csv-row-limit

or

npm install csv-row-limit

⌨️ Usage

import { csvRowLimit } from "csv-row-limit";

async function yourFunction() {
  const rows = await csvRowLimit({
    path: './data/example.csv', // local path or HTTP address
    maxRowCount: 1000, // maximum number of rows to limit
  });
}

📗 API

  • path: Required, the path of the CSV file. Local path or HTTP/HTTPS path.
  • maxRowCount: Required, the maximum value of rows to limit.
  • readLineOptions: Optional, customizable options when reading the CSV line by line, consistent with the createInterface method parameter of the readline module, see readline module for details.
  • requestOptions: Optional, customized options when reading HTTP files, consistent with the request method parameter of the http/https module, see http module for details.

💻 Contribution

Very welcome to participate in the contribution of the project, let's work together for the love of electricity!

If you are interested in this project or have ideas, please feel free to create a new Issue for discussion~

👨‍💻 Contributors

Currently, there is only one person in the project. Welcome to co-build~

1.0.1

2 years ago

1.0.0

2 years ago

1.0.0-beta

2 years ago