我有一个javascript文件应该循环遍历给定目录,索引文件,从中删除前端内容,然后将它们转换为PDF文件。
我的大部分流程都有效,但由于某些原因,我的.replace
功能似乎没有做任何事情。
以下是代码:
var fs = require( 'fs' );
var path = require( 'path' );
var process = require( 'process' );
var markdownpdf = require( 'markdown-pdf' )
var md_dir = "_pages";
var pdf_dir = "assets/pdf"
// Loop through all the files in the directory
fs.readdir( md_dir, function( err, files ) {
if( err ) {
console.error( "Could not list the directory.", err );
process.exit( 1 );
}
files.forEach( function( file, index ) {
// Make one pass and make the file complete
var md_path = path.join( md_dir, file );
var pdf_path = path.join( pdf_dir, file + '.pdf' );
fs.stat( md_path, function( error, stat ) {
if( error ) {
console.error( "Error stating file.", error );
return;
}
// Start PDF Process on the files
if( stat.isFile() ) {
console.log( "'%s' is a file.", md_path );
console.log( "Stripping Jekyll Front-Matter...");
var fileContents = fs.readFileSync(md_path, 'utf8');
var pattern = /^---\n.*\n---\n/;
// Strip everything between the first two sets of '---'
var stripped_md = fileContents.replace( pattern, '' );
console.log( "Front-Matter stripped." );
// Pass that to markdown-pdf
markdownpdf().from.string(stripped_md).to(pdf_path, function () {
console.log("Created", pdf_path)
} );
}
// If it's not a file
else if( stat.isDirectory() )
console.log( "'%s' is a directory.", md_path );
} );
} );
} );
答案 0 :(得分:1)
在正则表达式模式中。 char匹配除换行符之外的所有内容。
FrontMatter有换行符,因此您必须将其添加到模式中。
赞:var pattern = /^---(.|\n)*?---\n/;
其中说明了---"标签"
之间的所有内容或换行符?让它不贪心