Created
November 23, 2012 09:44
-
-
Save victorsollozzo/4134793 to your computer and use it in GitHub Desktop.
recursively find all files in a directory with given extension in node.js
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
var path = require('path') | |
var fs = require('fs') | |
function recFindByExt(base,ext,files,result) | |
{ | |
files = files || fs.readdirSync(base) | |
result = result || [] | |
files.forEach( | |
function (file) { | |
var newbase = path.join(base,file) | |
if ( fs.statSync(newbase).isDirectory() ) | |
{ | |
result = recFindByExt(newbase,ext,fs.readdirSync(newbase),result) | |
} | |
else | |
{ | |
if ( file.substr(-1*(ext.length+1)) == '.' + ext ) | |
{ | |
result.push(newbase) | |
} | |
} | |
} | |
) | |
return result | |
} | |
ext_file_list = recFindByExt('/mypath','ext') |
use a normalizeUrl npm module
Example:
const normalizeUrl = require('normalize-url');
var url = "public\\assets\\examples\\ind\\local-retail\\search\\search-and-view-item";
console.log(normalizeUrl(url));
Output: http://public/assets/examples/ind/local-retail/search/search-and-view-item
I would also add !path.extname(file)
just to make sure the function doesn't look inside a macOS .app
, because it's actually a folder.
I have it like this:
const path = require('path')
const { readdirSync, statSync } = require('fs-extra')
const findFiles = (dir, ext, files, result, regex) => {
files = files || readdirSync(dir)
result = result || []
regex = regex || new RegExp(`\\${ext}$`)
for (let i = 0; i < files.length; i++) {
let file = path.join(dir, files[i])
if (statSync(file).isDirectory() && !path.extname(file)) {
try {
result = findFiles(file, ext, readdirSync(file), result, regex)
} catch (error) {
continue
}
} else {
if (regex.test(file)) {
result.push(file)
}
}
}
return result
}
Just a recommendation, it would be safer and cleaner replacing the line 18:
if ( file.substr(-1*(ext.length+1)) == '.' + ext )
With the String method endsWith
:
if (file.endsWith(featureExtension)) {
Anyway, great job, you inspired and helped a lot of people. Thank you!!
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
The above function generates this type of error:
I made a workaround that uses a standard for loop instead of foreach loop, whenever it encounters an error of not able to read the directory it just continues the for loop leaving that directory. And this works fine for me.
Code:
Output: