例如,假设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()是一个函数,做字符检查。
当前回答
下面是另一个基于正则表达式的解决方案:
filename.replace(/\.[^.$]+$/, '');
这应该只切掉最后一部分。
其他回答
虽然已经很晚了,但我将添加另一种方法,使用普通的旧JS-获取没有扩展名的文件名
path.replace (path.substr (path.lastIndexOf ('.')), '')
即使在字符串中不存在分隔符时,这也是有效的。
String.prototype.beforeLastIndex = function (delimiter) {
return this.split(delimiter).slice(0,-1).join(delimiter) || this + ""
}
"image".beforeLastIndex(".") // "image"
"image.jpeg".beforeLastIndex(".") // "image"
"image.second.jpeg".beforeLastIndex(".") // "image.second"
"image.second.third.jpeg".beforeLastIndex(".") // "image.second.third"
也可以像这样作为一行代码使用:
var filename = "this.is.a.filename.txt";
console.log(filename.split(".").slice(0,-1).join(".") || filename + "");
编辑:这是一个更有效的解决方案:
String.prototype.beforeLastIndex = function (delimiter) {
return this.substr(0,this.lastIndexOf(delimiter)) || this + ""
}
我喜欢这篇文章,因为它只有一行字,读起来不难:
filename.substring(0, filename.lastIndexOf('.')) || filename
如果你使用的是Node.js,一个简单的答案就是第一条注释。 我的任务是我需要从Node服务器中删除Cloudinary中的一个图像,我只需要获得图像名称。 例子:
const path = require("path")
const image=xyz.jpg;
const img= path.parse(image).name
console.log(img) // xyz
X.length-4只支持3个字符的扩展。如果有filename。jpeg或filename。pl呢?
编辑:
回答……当然,如果您总是使用.jpg扩展名,x.length-4就可以了。
但是,如果您不知道扩展的长度,那么许多解决方案中的任何一个都更好/更健壮。
x = x.replace(/\..+ $ / ');
OR
x = x.substring(0, x. lastindexof ('.'));
OR
X = X .replace(/(.*)\.(.*?)$/, "$1");
OR(假设文件名只有一个点)
parts = x.match(/[^\.]+/);
x = parts[0];
OR(也是只有一个点)
parts = x.split(".");
x = parts[0];