JSPM

  • ESM via JSPM
  • ES Module Entrypoint
  • Export Map
  • Keywords
  • License
  • Repository URL
  • TypeScript Types
  • README
  • Created
  • Published
  • Downloads 11
  • Score
    100M100P100Q28239F
  • License MIT

A Node.js package for merging large JSON files using streams

Package Exports

  • json-file-merger
  • json-file-merger/dist/index.js

This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (json-file-merger) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.

Readme

JSON File Merger

A Node.js package for merging large JSON files using streams, designed to handle files that are too large to fit in memory. The official release of another package I created for my job that never existed in a repository.

Features

  • Stream-based processing for memory-efficient handling of large JSON files
  • Supports merging multiple JSON files into a single JSON array
  • No memory limitations as it processes files in chunks
  • Maintains JSON formatting in the output file
  • Command-line interface for easy use
  • Support for merging all JSON files from a directory
  • Wildcard pattern support for flexible file selection

Installation

npm install json-file-merger

Usage

As a Node.js Module

const { mergeJsonFiles } = require('json-file-merger');

// Example usage
async function example() {
  try {
    await mergeJsonFiles(
      ['file1.json', 'file2.json', 'file3.json'],
      'merged-output.json'
    );
    console.log('Files merged successfully!');
  } catch (error) {
    console.error('Error merging files:', error);
  }
}

Command Line Interface

After installation, you can use the package from the command line:

# Merge specific files
json-file-merger output.json input1.json input2.json input3.json

# Merge files using wildcards
json-file-merger output.json "data/*.json"
json-file-merger output.json "**/*.json"  # Recursive search
json-file-merger output.json "data-*.json" # Pattern matching

# Merge all JSON files from a directory
json-file-merger output.json --directory ./json-files

# Combine directory and specific files with wildcards
json-file-merger output.json --directory ./json-files "additional/*.json"

# Suppress console output
json-file-merger -s output.json --directory ./json-files

# Show help
json-file-merger --help

Features

Directory Support

The --directory option allows you to merge all JSON files from a specified directory. This is useful when you have multiple JSON files that need to be combined. The output file will be written to the current working directory, and if it's in the same directory as the input files, it will be automatically excluded from the merge process.

Wildcard Support

The package supports glob patterns for flexible file selection. You can use patterns like:

  • *.json - Match all JSON files in the current directory
  • **/*.json - Match all JSON files in the current directory and subdirectories
  • data-*.json - Match all JSON files starting with "data-"
  • data/*.json - Match all JSON files in the data directory

API

mergeJsonFiles(inputFiles, outputFile, options)

Merges multiple JSON files into a single JSON array.

Parameters

  • inputFiles (string[]): Array of input file paths to merge
  • outputFile (string): Path where the merged JSON will be written
  • options (object): Optional configuration
    • onProgress (function): Callback function that receives progress information
      {
        progress: number,        // Progress percentage (0-100)
        processedBytes: number,  // Number of bytes processed
        speed: number,          // Processing speed in MB/s
        buffer: {               // Buffer information
          size: number,         // Current buffer size
          maxSize: number       // Maximum buffer size reached
        }
      }

Returns

  • Promise: Resolves when all files are merged

Throws

  • Error: If input files array is empty or invalid

Project Structure

The project follows a modular structure for better maintainability:

src/
├── index.js           # Main entry point
├── streams/           # Stream-related implementations
│   └── json-stream-merger.js
├── utils/            # Utility functions
│   └── file-utils.js
└── types/            # Type definitions
    └── index.js

Testing

To run the tests, clone the repository and run:

# Run the main test suite
node test/test.js

# Run the interruption test
node test/test-interruption.js

Tests cover:

  • Basic file merging
  • Large file handling
  • Progress reporting
  • Interruption handling
  • Error cases

The test suite will:

  • Generate test files of various sizes
  • Test merging of JSON files
  • Verify the output file structure and content
  • Test memory efficiency and streaming performance
  • Clean up test files after completion

Performance

The package is designed for high-performance merging of large JSON files:

  • Stream-based processing with no memory limitations
  • Dynamic chunk sizing based on total file size
  • Memory-efficient object handling
  • Progress tracking with speed metrics
  • Typical processing speeds of 600+ MB/s

License

MIT