例如,假设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()
而是函数,则进行字符检查。
Answers:
如果知道扩展名的长度,则可以使用x.slice(0, -4)
(其中4是扩展名和点的三个字符)。
如果您不知道@John Hartsock regex的长度是正确的方法。
如果您不想使用正则表达式,则可以尝试以下方法(性能较低):
filename.split('.').slice(0, -1).join('.')
请注意,它将在没有扩展名的文件上失败。
.jpg
。我一直在寻找Ruby的东西x[0..-5]
,x.slice(0, -4)
看起来很棒!谢谢!并感谢其他所有人提供的所有其他强大替代方案!
"picture.jpeg".slice(0, -4)
->“图片”。
不知道会执行得更快,但是当涉及到分机这样会更可靠.jpeg
或.html
x.replace(/\.[^/.]+$/, "")
在node.js中,不带扩展名的文件名可以按以下方式获取。
const path = require('path');
const filename = 'hello.html';
path.parse(filename).name; // hello
path.parse(filename).ext; // .html
Node.js 文档页面上的进一步说明。
var parsed = path.parse(filename)
后面path.join(parsed.dir, parsed.name)
。
let base = path.basename( file_path, path.extname( file_path ) )
。
x.length-4
仅占3个字符的扩展名。如果有filename.jpeg
或该filename.pl
怎么办?
编辑:
要回答...当然,如果您始终使用的扩展名.jpg
,则x.length-4
可以正常工作。
但是,如果您不知道扩展名的长度,那么许多解决方案中的任何一种都会更好/更可靠。
x = x.replace(/\..+$/, '');
要么
x = x.substring(0, x.lastIndexOf('.'));
要么
x = x.replace(/(.*)\.(.*?)$/, "$1");
或(假设文件名只有一个点)
parts = x.match(/[^\.]+/);
x = parts[0];
或(也只有一个点)
parts = x.split(".");
x = parts[0];
var parts = full_file.split("."); var ext = parts[parts.length-1]; var file = parts.splice(0,parts.length-1).join(".");
x = x.substr(0, x.lastIndexOf('.'));
-你可能是说x = x.substring(0, x.lastIndexOf('.'));
什么?
您也许可以假设最后一个点将是扩展定界符。
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);
}
var f = x.substr(0, x.lastIndexOf('.')) || x;
这是有效的,因为空字符串是虚假的,因此它返回x。
在0.12.x之前的Node.js版本中:
path.basename(filename, path.extname(filename))
当然,这也适用于0.12.x及更高版本。
path.parse
回答是简单的。
即使在字符串中不存在分隔符的情况下,此方法也有效。
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 + ""
}
我不知道这是不是一个有效的选项,但是我使用了这个:
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('.').slice(0, -1)).join('.')
hello.name.txt
返回hello, name
var fileName = "something.extension";
fileName.slice(0, -path.extname(fileName).length) // === "something"
path/name.ext
-> paht/name
而不是仅仅返回name
,但是我宁愿这样做,fs.parse
尽管它有点冗长:stackoverflow.com/a/59576950/895245
如果您必须处理包含完整路径的变量(例如:),thePath = "http://stackoverflow.com/directory/subdirectory/filename.jpg"
并且只想返回“文件名”,则可以使用:
theName = thePath.split("/").slice(-1).join().split(".").shift();
结果将是theName ==“ filename” ;
要进行尝试,请将以下命令写入chrome调试器的控制台窗口:
window.location.pathname.split("/").slice(-1).join().split(".").shift()
如果您只需要处理文件名及其扩展名(例如:)theNameWithExt = "filename.jpg"
:
theName = theNameWithExt.split(".").shift();
结果将是theName ==“ filename”,与上面相同;
但是我既不能与其他答案进行性能比较,也不能与浏览器或操作系统兼容。
工作片段1:完整路径
var thePath = "http://stackoverflow.com/directory/subdirectory/filename.jpg";
theName = thePath.split("/").slice(-1).join().split(".").shift();
alert(theName);
工作片段2:带有扩展名的文件名
var theNameWithExt = "filename.jpg";
theName = theNameWithExt.split("/").slice(-1).join().split(".").shift();
alert(theName);
工作片段2:具有双扩展名的文件名
var theNameWithExt = "filename.tar.gz";
theName = theNameWithExt.split("/").slice(-1).join().split(".").shift();
alert(theName);
尽管已经很晚了,但我将添加另一种方法,使用普通的旧JS-来获取不带扩展名的文件名
path.replace(path.substr(path.lastIndexOf('.')), '')
path.split('.').pop()
一部分文件扩展名
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, -(x.split('.').pop().length + 1));
这是我用来从文件名中删除扩展名的代码,而不使用regex或indexOf(IE8不支持indexOf)。它假定扩展名是最后一个“。”之后的任何文本。字符。
它适用于:
这是代码:
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;
}
hello.tar.gz
,输出为hellotar
。
我会使用x.substring(0,x.lastIndexOf('。'))之类的东西。如果您要提高性能,那么根本不要使用javascript:-p不,对于99.99999%的所有用途,再声明一次并不重要。