Get the size of a folder by iterating through its sub-files and -folders.
Version 3+ of this package is pure ESM and uses a new promise-based API. If you need to use CommonJS or the old callback syntax, keep your dependency pinned to version ^2 (v2 API reference). |
---|
If you don't care about the details and just want a quick implementation, you can use:
getFolderSize.loose('/path/to/folder');
Example:
import getFolderSize from 'get-folder-size';
const myFolder = '/path/to/my/folder';
const size = await getFolderSize.loose(myFolder);
console.log(`The folder is ${size} bytes large`);
console.log(`That is the same as ${(size / 1000 / 1000).toFixed(2)} MB`);
When reading the size of a folder, read errors can randomly occur for a number of reasons, especially if a different process is altering files in the same folder at the same time. There are three different ways to call this package, depending on how you want to handle those errors:
The default method will return an object with the size of the folder and a list of encountered errors:
{
size: 1435,
errors: [
Error{} ...
]
}
If no errors were encountered, errors
will be null
. If errors were encountered, size
will likely be smaller than the real folder size.
This method is great if you want to implement custom logic based on the errors that were encountered.
The loose
method will return the folder size directly and ignore any errors it encounters, which means the returned folder size could be smaller than the real folder size.
This method is great if the precise size isn't too important, for example when used only to display the folder size to the user.
The strict
method will return the folder size directly, but throw an error if it encounters any read errors.
This method is great if you need a very accurate number. You will have to implement some sort of error handling to use it reliably.
Any of the three methods can also take an options
object:
getFolderSize(
'/path/to/folder',
{
bigint: true,
ignore: /pattern/,
fs: customFS,
}
)
If the bigint
option is set to true, the folder size is returned as a BigInt instead of the default Number.
The ignore
option takes a regex pattern. Any file or folder with a path that matches the pattern will not be counted in the total folder size.
The fs
option allows you to pass a different filesystem handler, such as memfs, that will be used to read the folder size. The filesystem handler must incorporate lstat
and readdir
promise functions.
You can run this module from your command line:
get-folder-size --folder="/my/folder" --ignore="node_modules"
The optional ignore
statement takes a regex pattern.
If a file is passed to get-folder-size
, it will simply return the size of the file. This means you can use it as a catch-all to get the size of any element in the filesystem.
Example:
import getItemSize from 'get-folder-size';
for(const path of [
'/path/to/small/file.txt',
'/path/to/small/folder/',
'/path/to/large/file.js',
'/path/to/large/folder/',
]){
console.log(await getItemSize.strict(path));
}
// Console:
// 273
// 402
// 348614
// 674362319
This module calculates the actual folder size, and not the size on disk. Read about the difference here.
CommonJS modules do not support the import..from
method, but they do support this method:
const getFolderSize = (await import("get-folder-size")).default;
Note that this import only works inside an async function.
If you want to use the require
method, consider just staying on v2. You can make v2 return a promise by importing it this way:
const util = require("util");
const getFolderSize = util.promisify(require("get-folder-size"));
If none of these methods work for you, send us a detailed explanation of your issue, and we will take a look at it.
This is a Node module. If you are not sure what that means, please check out one of the many great tutorials online, like nodejs.dev.
When you have Node set up, you can install get-folder-size
from your command line with this command:
npm install get-folder-size
You can now import it into your JavaScript files, or you can use its command line interface (CLI).
MIT