java使用File写入文件出现java.io.FileNotFoundException错误解决办法(无法生成文件而是生成目录)

java使用File写入文件图片出现java.io.FileNotFoundException错误解决办法(无法生成文件而是生成目录)

java.io.FileNotFoundException错误解决(使用!f.isDirectory()判断)

入坑许久,这个错误让我头疼了一下午。当我们使用File类创建文件时,会遇见被拒绝访问的错误异常。本人在网上搜索基本都是后缀名没有添加,但是这也无法解决本人问题(磁盘写入权限已检查,没有问题),以致我认为是电脑出现了问题。但在我仔细检查后,发现是方法逻辑问题。

修改前代码

FileOutputStream fos = null;
File f = new  File("f:\\upload\\temp.txt");
if (!f.isDirectory()){
    f.mkdirs();
}
fos = new FileOutputStream(f);

执行后
在这里插入图片描述

你可能会觉得这段代码没错,但是它无法生成.txt文件还会java.io.FileNotFoundException错误,并且生成一个命名temo.txt的文件夹。问题就在于!f.isDirectory(),它把temo.txt当成一个目录判断为不存在了,就执行了 f.mkdirs();生成了该目录。

修改后代码

FileOutputStream fos = null;
File f = new  File("f:\\upload");
if (!f.isDirectory()){
	f.mkdirs();
}
f = new  File("f:\\upload\\temp.txt");
fos = new FileOutputStream(f);

从代码可以看出,我们可以先判断目录是否存在,并创建,然后再创建文件。

执行后
在这里插入图片描述
问题解决,开心。

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
zip压缩DLL 可以使用程序自己来控制 压缩,解压. c#使用代码如下: /// /// 压缩和解压文件 /// public class ZipClass { /// /// 所有文件缓存 /// List files = new List(); /// /// 所有空目录缓存 /// List paths = new List(); /// /// 压缩单个文件 /// /// 要压缩的文件 /// 压缩后的文件全名 /// 压缩程度,范围0-9,数值越大,压缩程序越高 /// 分块大小 public void ZipFile(string fileToZip, string zipedFile, int compressionLevel, int blockSize) { if (!System.IO.File.Exists(fileToZip))//如果文件没有找到,则报错 { throw new FileNotFoundException("The specified file " + fileToZip + " could not be found. Zipping aborderd"); } FileStream streamToZip = new FileStream(fileToZip, FileMode.Open, FileAccess.Read); FileStream zipFile = File.Create(zipedFile); ZipOutputStream zipStream = new ZipOutputStream(zipFile); ZipEntry zipEntry = new ZipEntry(fileToZip); zipStream.PutNextEntry(zipEntry); zipStream.SetLevel(compressionLevel); byte[] buffer = new byte[blockSize]; int size = streamToZip.Read(buffer, 0, buffer.Length); zipStream.Write(buffer, 0, size); try { while (size < streamToZip.Length) { int sizeRead = streamToZip.Read(buffer, 0, buffer.Length); zipStream.Write(buffer, 0, sizeRead); size += sizeRead; } } catch (Exception ex) { GC.Collect(); throw ex; } zipStream.Finish(); zipStream.Close(); streamToZip.Close(); GC.Collect(); } /// /// 压缩目录(包括子目录及所有文件) /// /// 要压缩的根目录 /// 保存路径 /// 压缩程度,范围0-9,数值越大,压缩程序越高 public void ZipFileFromDirectory(string rootPath, string destinationPath, int compressLevel) { GetAllDirectories(rootPath); /* while (rootPath.LastIndexOf("\\") + 1 == rootPath.Length)//检查路径是否以"\"结尾 { rootPath = rootPath.Substring(0, rootPath.Length - 1);//如果是则去掉末尾的"\" } */ //string rootMark = rootPath.Substring(0, rootPath.LastIndexOf("\\") + 1);//得到当前路径的位置,以备压缩时将所压缩内容转变成相对路径。 string rootMark = rootPath + "\\";//得到当前路径的位置,以备压缩时将所压缩内容转变成相对路径。 Crc32 crc = new Crc32(); ZipOutputStream outPutStream = new ZipOutputStream(File.Create(destinationPath)); outPutStream.SetLevel(compressLevel); // 0 - store only to 9 - means best compression foreach (string file in files) { FileStream fileStream = File.OpenRead(file);//打开压缩文件 byte[] buffer = new byte[fileStream.Length]; fileStream.Read(buffer, 0, buffer.Length); ZipEntry entry = new ZipEntry(file.Replace(rootMark, string.Empty)); entry.DateTime = DateTime.Now; // set Size and the crc, because the information // about the size and crc should be stored in the header // if it is not set it is automatically written in the footer. // (in this case size == crc == -1 in the header) // Some ZIP programs have problems with zip files that don't store // the size and crc in the header. entry.Size = fileStream.Length; fileStream.Close(); crc.Reset(); crc.Update(buffer); entry.Crc = crc.Value; outPutStream.PutNextEntry(entry); outPutStream.Write(buffer, 0, buffer.Length); } this.files.Clear(); foreach (string emptyPath in paths) { ZipEntry entry = new ZipEntry(emptyPath.Replace(rootMark, string.Empty) + "/"); outPutStream.PutNextEntry(entry); } this.paths.Clear(); outPutStream.Finish(); outPutStream.Close(); GC.Collect(); } /// /// 取得目录下所有文件文件夹,分别存入files及paths /// /// 根目录 private void GetAllDirectories(string rootPath) { string[] subPaths = Directory.GetDirectories(rootPath);//得到所有子目录 foreach (string path in subPaths) { GetAllDirectories(path);//对每一个字目录做与根目录相同的操作:即找到子目录并将当前目录文件名存入List } string[] files = Directory.GetFiles(rootPath); foreach (string file in files) { this.files.Add(file);//将当前目录中的所有文件全名存入文件List } if (subPaths.Length == files.Length && files.Length == 0)//如果是空目录 { this.paths.Add(rootPath);//记录空目录 } } /// /// 解压缩文件(压缩文件中含有子目录) /// /// 待解压缩的文件路径 /// 解压缩到指定目录 /// 解压后的文件列表 public List UnZip(string zipfilepath, string unzippath) { //解压出来的文件列表 List unzipFiles = new List(); //检查输出目录是否以“\\”结尾 if (unzippath.EndsWith("\\") == false || unzippath.EndsWith(":\\") == false) { unzippath += "\\"; } ZipInputStream s = new ZipInputStream(File.OpenRead(zipfilepath)); ZipEntry theEntry; while ((theEntry = s.GetNextEntry()) != null) { string directoryName = Path.GetDirectoryName(unzippath); string fileName = Path.GetFileName(theEntry.Name); //生成解压目录【用户解压到硬盘根目录时,不需要创建】 if (!string.IsNullOrEmpty(directoryName)) { Directory.CreateDirectory(directoryName); } if (fileName != String.Empty) { //如果文件的压缩后大小为0那么说明这个文件是空的,因此不需要进行读出写入 if (theEntry.CompressedSize == 0) break; //解压文件到指定的目录 directoryName = Path.GetDirectoryName(unzippath + theEntry.Name); //建立下面的目录和子目录 Directory.CreateDirectory(directoryName); //记录导出的文件 unzipFiles.Add(unzippath + theEntry.Name); FileStream streamWriter = File.Create(unzippath + theEntry.Name); int size = 2048; byte[] data = new byte[2048]; while (true) { size = s.Read(data, 0, data.Length); if (size > 0) { streamWriter.Write(data, 0, size); } else { break; } } streamWriter.Close(); } } s.Close(); GC.Collect(); return unzipFiles; } }
对数据源进行分析,是为建立索引服务的;为指定的文件建立索引,是为检索服务的。 对数据源分析,使用Lucene的分析器(Analyzer),根据分析器所得到的词条,构造一个索引器IndexWriter。索引器IndexWriter的功能主要就是创建索引,是建立索引工作中最核心的。 当构造完一个索引器IndexWriter之后,就可以向其中添加Document了。 在前面Lucene-2.2.0 源代码阅读学习(1)中,根据Lucene提供的一个Demo,详细分析研究一下索引器org.apache.lucene.index.IndexWriter类,看看它是如果定义的,掌握它建立索引的机制。 通过IndexWriter类的实现源代码可知,它包含的内容相当丰富了。乍一看无从入手,不知道从何处去分析。可以通过Lucene提供的Demo的,根据它的实现过程l来一点点地解析。 在Demo中,实例化一个索引器: IndexWriter writer = new IndexWriter(INDEX_DIR, new StandardAnalyzer(), true); 它使用的IndexWriter的一个构造函数,定义如下所示: public IndexWriter(String path, Analyzer a, boolean create) throws CorruptIndexException, LockObtainFailedException, IOException { init(FSDirectory.getDirectory(path), a, create, true, null, true); } 这个构造函数具有三个参数: path :根据一个字符串描述的路径,为建立的索引文件指定存放目录。 a :一个分析器。 create:它是一个boolean型变量,如果为true,表示要重写指定的存放索引目录下的索引文件;如果为false,表示在指定存放索引目录下已经存在的索引文件的基础上,向其中继续追加新的索引文件。 简单做个测试吧: package org.shirdrn.lucene; import java.io.IOException; import org.apache.lucene.analysis.Analyzer; import org.apache.lucene.analysis.standard.StandardAnalyzer; import org.apache.lucene.index.CorruptIndexException; import org.apache.lucene.index.IndexWriter; import org.apache.lucene.store.LockObtainFailedException; public class MyIndexWriterTest { public static void main(String[] args) throws Exception { String path = "E:\\index"; Analyzer a = new StandardAnalyzer(); IndexWriter myWriter = new IndexWriter(path,a,true); } } 这里没有指定要进行建立索引的文件,因此,应该是“建立空索引”。这里,指定了create的值为true,是新建索引文件。 这里,只是实例化了一个IndexWriter索引器,并没有建立索引。建立索引的过程是在一个IndexWriter索引器实例存在的前提下,通过为其添加Document,这样才能真正就爱你里索引。 运行程序,可以在指定的索引文件的存放目录E:\\index下看到生成的三个与索引有关的文件: segments.gen (大小为1K) segments_1 (大小为1K) write.lock (大小为0K) 如果再次运行程序,会发现文件segments_1变成了segments_2,再次运行还会变成segments_3……,这就说明参数create为true表示重写现存的索引文件。 如果第一次执行上述程序,指定create为false,由于指定的索引目录下面缺少被追加索引的索引文件,将会抛出异常: Exception in thread "main" java.io.FileNotFoundException: no segments* file found in org.apache.luce
### 回答1: java.io.filenotfoundexception: openfailed: enoent (no such file or directory)是Java程序中常见的异常之一,表示在指定路径或目录下找不到文件文件夹。 通常这种异常会在程序尝试打开一个文件时发生,可能是因为路径错误文件不存在或者没有权限等原因导致。解决该异常的方法是检查程序中读取或写入文件的路径是否正确,确认文件是否存在,以及确保程序有足够的权限访问目标文件。 在处理该异常时,可以使用Java的异常处理机制来捕获该异常并给出相应的提示信息,如未找到文件目录,请检查路径是否正确、文件是否存在、是否有权限等。同时,对于无法处理的情况,可以通过向用户显示错误消息或记录日志来提醒用户或开发者。 总之,遇到java.io.filenotfoundexception: openfailed: enoent (no such file or directory)异常时,一定不要惊慌,需要对代码进行仔细检查,找出问题所在,最终通过适当的处理方法来解决问题。 ### 回答2: 这个错误提示是Java编程中常见的IO异常之一。它产生的原因是程序尝试打开一个不存在的文件文件夹。 当程序运行时,它会尝试打开一个指定的文件文件夹。如果这个文件文件夹不存在,那么Java就会抛出这个异常。通常这个错误提示会指示程序在执行open方法时出错,因为找不到指定的文件文件夹。 如果你遇到了这个问题,首先要检查的是你的文件路径是否正确。你应该确保你指定的路径是一个存在的文件文件夹。如果这个路径确实存在,那么你还需要检查该路径是否可读,是否被占用等等。 此外,这个错误提示也可能是由于文件权限的问题所致。如果你正在尝试读取或写入一个文件,但是你没有足够的权限来访问它,那么Java就会抛出这个异常。 总之,要解决这个问题,你需要仔细检查你的代码,确保文件路径正确并且你有足够的权限来访问它。如果问题仍未解决,你可能需要查看更多的异常信息来确定具体的原因。 ### 回答3: Java是一种运行于虚拟机上的编程语言。Java提供了一套完整的API,包括操作文件系统的API。在Java程序中,当我们想要打开一个文件时,会出现如下提示:java.io.filenotfoundexception: openfailed: enoent (no such file or directory)。 该异常表示在尝试打开该文件之前,Java未找到指定的文件目录。通常情况下,这种错误会由于路径错误文件名输入错误而引起。解决这个问题的方法如下: 1. 检查文件路径是否正确: 当我们向打开文件时,指定的文件路径必须是正确的。如果文件路径不正确,则会出现java.io.filenotfoundexception异常。因此,我们需要确保路径是指向正确的文件目录。 2. 检查文件名是否正确: 文件名可能会输入错误,例如,大小写可能会错误地输入或者忘记输入扩展名。在这种情况下,我们需要检查文件名是否正确,并且输入的大小写是否符合实际情况。 3. 检查文件是否存在: 在尝试打开文件之前,我们需要确保该文件真正存在。因此,我们需要检查该文件是否存在,如果不存在,则需要创建新文件或引发NoSuchFileException异常。 总之,当我们在Java程序中打开文件时,如果出现java.io.filenotfoundexception: openfailed: enoent (no such file or directory)异常,我们需要首先检查路径和文件名是否正确,并且确保文件真实存在。如果以上三种方法无法解决问题,我们需要检查文件系统中的权限问题,或者文件是否正在使用等其他问题。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值