例如,假设x = filename.jpg,我想要获取filename,其中filename可以是任何文件名(为了简化,我们假设文件名只包含[a-zA-Z0-9-_])。
我看到x.substring(0, x.indexOf('.jpg'))在DZone片段上,但x.substring(0, x.length-4)不会表现更好吗?因为,length是一个属性,不做字符检查,而indexOf()是一个函数,做字符检查。
例如,假设x = filename.jpg,我想要获取filename,其中filename可以是任何文件名(为了简化,我们假设文件名只包含[a-zA-Z0-9-_])。
我看到x.substring(0, x.indexOf('.jpg'))在DZone片段上,但x.substring(0, x.length-4)不会表现更好吗?因为,length是一个属性,不做字符检查,而indexOf()是一个函数,做字符检查。
当前回答
在node.js中,不带扩展名的文件名可以通过如下方式获取。
const path = require('path');
const filename = 'hello.html';
path.parse(filename).name; //=> "hello"
path.parse(filename).ext; //=> ".html"
path.parse(filename).base; //=> "hello.html"
进一步的解释在Node.js文档页。
其他回答
我喜欢用正则表达式来做。它很短,很容易理解。
(const regexppattern of [] / \ . .+$/, //查找第一个圆点及其后面的所有内容。 / \[^ /。+$/ //获取最后一个圆点及其后面的所有内容。 ) { console.log(“myFont.ttf”。替换(regexPattern”、“)) console.log(“myFont.ttf.log”。替换(regexPattern”、“)) } / *输出 myFont myFont myFont myFont.ttf * /
上述解释可能不是很严谨。如果您想获得更准确的解释,可以访问regex101进行检查
美元\ . . + \[^ /。]。+美元
var fileName = "something.extension";
fileName.slice(0, -path.extname(fileName).length) // === "something"
Node.js从全路径保存目录中删除扩展
例如https://stackoverflow.com/a/31615711/895245做了path/hello.html -> hello,但如果你想要path/hello.html -> path/hello,你可以使用这个:
#!/usr/bin/env node
const path = require('path');
const filename = 'path/hello.html';
const filename_parsed = path.parse(filename);
console.log(path.join(filename_parsed.dir, filename_parsed.name));
输出目录以及:
path/hello
https://stackoverflow.com/a/36099196/895245也实现了这一点,但我发现这种方法在语义上更讨人喜欢。
在Node.js v10.15.2中测试。
如果知道扩展的长度,可以使用x.slice(0, -4)(其中4是扩展的三个字符和点)。
如果你不知道长度@John Hartsock正则表达式将是正确的方法。
如果你不想使用正则表达式,你可以试试这个(性能更差):
filename.split('.').slice(0, -1).join('.')
注意,它将在没有扩展名的文件上失败。
您也许可以假设最后一个点是扩展分隔符。
var x = 'filename.jpg';
var f = x.substr(0, x.lastIndexOf('.'));
如果文件没有扩展名,它将返回空字符串。要解决这个问题,请使用这个函数
function removeExtension(filename){
var lastDotPosition = filename.lastIndexOf(".");
if (lastDotPosition === -1) return filename;
else return filename.substr(0, lastDotPosition);
}