例如,假设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()是一个函数,做字符检查。
当前回答
我喜欢用正则表达式来做。它很短,很容易理解。
(const regexppattern of [] / \ . .+$/, //查找第一个圆点及其后面的所有内容。 / \[^ /。+$/ //获取最后一个圆点及其后面的所有内容。 ) { console.log(“myFont.ttf”。替换(regexPattern”、“)) console.log(“myFont.ttf.log”。替换(regexPattern”、“)) } / *输出 myFont myFont myFont myFont.ttf * /
上述解释可能不是很严谨。如果您想获得更准确的解释,可以访问regex101进行检查
美元\ . . + \[^ /。]。+美元
其他回答
如果知道扩展的长度,可以使用x.slice(0, -4)(其中4是扩展的三个字符和点)。
如果你不知道长度@John Hartsock正则表达式将是正确的方法。
如果你不想使用正则表达式,你可以试试这个(性能更差):
filename.split('.').slice(0, -1).join('.')
注意,它将在没有扩展名的文件上失败。
不知道哪个会执行得更快,但当涉及到。jpeg或。html等扩展名时,这将更可靠
x.replace(/\.[^/.]+$/, "")
如果你使用的是Node.js,一个简单的答案就是第一条注释。 我的任务是我需要从Node服务器中删除Cloudinary中的一个图像,我只需要获得图像名称。 例子:
const path = require("path")
const image=xyz.jpg;
const img= path.parse(image).name
console.log(img) // xyz
name.split('.').slice(0, -1).join('.')
这就是所有的享受你的编码…
接受的答案只删除了最后一个扩展部分(.jpeg),这在大多数情况下可能是一个不错的选择。
我曾经不得不剥离所有扩展名(.tar.gz),文件名被限制为不包含点(所以2015-01-01.backup.tar不会有问题):
var name = "2015-01-01_backup.tar.gz";
name.replace(/(\.[^/.]+)+$/, "");