例如,假设x = filename.jpg,我想要获取filename,其中filename可以是任何文件名(为了简化,我们假设文件名只包含[a-zA-Z0-9-_])。

我看到x.substring(0, x.indexOf('.jpg'))在DZone片段上,但x.substring(0, x.length-4)不会表现更好吗?因为,length是一个属性,不做字符检查,而indexOf()是一个函数,做字符检查。


当前回答

另一行-我们假设我们的文件是一个jpg图片>> ex: var yourStr = 'test.jpg';

    yourStr = yourStr.slice(0, -4); // 'test'

其他回答

简单的一个:

var n = str.lastIndexOf(".");
return n > -1 ? str.substr(0, n) : str;

这是我用来从文件名中删除扩展名的代码,不使用regex或indexOf (indexOf在IE8中不支持)。它假定扩展名是最后一个'之后的任何文本。'字符。

它适用于:

没有扩展名的文件:"myletter" 使用'文件。"my.letter.txt" 未知文件扩展名长度:"my.letter.html"

代码如下:

var filename = "my.letter.txt" // some filename

var substrings = filename.split('.'); // split the string at '.'
if (substrings.length == 1)
{
  return filename; // there was no file extension, file was something like 'myfile'
}
else
{
  var ext = substrings.pop(); // remove the last element
  var name = substrings.join(""); // rejoin the remaining elements without separator
  name = ([name, ext]).join("."); // readd the extension
  return name;
}

如果你使用的是Node.js,一个简单的答案就是第一条注释。 我的任务是我需要从Node服务器中删除Cloudinary中的一个图像,我只需要获得图像名称。 例子:

const path = require("path")
const image=xyz.jpg;
const img= path.parse(image).name
console.log(img) // xyz

我不知道这是否是一个有效的选项,但我使用这个:

name = filename.split(".");
// trimming with pop()
name.pop();
// getting the name with join()
name.join('.'); // we split by '.' and we join by '.' to restore other eventual points.

这不仅仅是我知道的一种操作,但至少它应该总是有效的!

更新:如果你想要一个在线,这里你是:

(name.split(“。”)。片(0,1)). join(“。”)

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中测试。