- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一些 .csv 文件,我将其用作测试台的一部分。我可以毫无问题地打开它们并读取它们除非我已经在 Excel 中打开了文件,在这种情况下我会收到 IOException
:
System.IO.IOException : The process cannot access the file 'TestData.csv' because it is being used by another process.
这是测试台的片段:
using (CsvReader csv = new CsvReader(new StreamReader(new FileStream(fullFilePath, FileMode.Open, FileAccess.Read)), false))
{
// Process the file
}
这是 StreamReader 的限制吗?我可以在其他应用程序(例如 Notepad++)中打开该文件,因此这不可能是操作系统问题。也许我需要使用其他类(class)?如果有人知道我如何解决这个问题(除了关闭 Excel!),我将非常感激。
最佳答案
正如 Jared 所说,除非打开文件的其他实体允许共享读取,否则您无法执行此操作。 Excel 允许共享读取,即使对于它已打开用于写入的文件也是如此。因此,您必须使用 FileShare.ReadWrite 参数打开文件流。
FileShare 参数经常被误解。它指示文件的其他打开程序可以执行的操作。它适用于过去和 future 的开场白。不要将 FileShare 视为对先前打开程序(例如 Excel)的追溯禁令,而是当前打开或任何 future 打开时不得违反的约束。
在当前尝试打开文件的情况下,FileShare.Read 表示“仅当任何先前的打开程序已打开该文件仅进行读取时,才能成功为我打开此文件。”如果您在 Excel 打开以进行写入的文件上指定 FileShare.Read,则您的打开操作将失败,因为这会违反约束,因为 Excel 已将其打开以进行写入 .
由于 Excel 打开文件进行写入,因此如果您希望成功打开该文件,则必须使用 FileShare.ReadWrite 打开该文件。另一种思考 FileShare 参数的方式:它指定“其他人的文件访问权限”。
现在假设一个不同的场景,您正在打开一个当前未被任何其他应用程序打开的文件。 FileShare.Read 说“ future 的打开者只能使用读取访问权限打开文件”。
从逻辑上讲,这些语义是有意义的 - FileShare.Read 意味着,如果其他人已经写入文件,您不想读取该文件,并且如果您已经写入文件,您也不希望其他人写入该文件阅读它。 FileShare.ReadWrite 意味着,即使另一个人正在写入文件,您也愿意读取该文件,并且在您读取文件时让另一个打开者写入文件也没有问题。
在任何情况下都不允许多个作者。 FileShare 类似于数据库隔离级别。您所需的设置取决于您所需的“一致性”保证。
示例:
using (Stream s = new FileStream(fullFilePath,
FileMode.Open,
FileAccess.Read,
FileShare.ReadWrite))
{
...
}
或者,
using (Stream s = System.IO.File.Open(fullFilePath,
FileMode.Open,
FileAccess.Read,
FileShare.ReadWrite))
{
}
<小时/>
附录:
documentation on System.IO.FileShare有点 slim 。如果您想了解最直接的事实,请访问the documentation for the Win32 CreateFile function ,这更好地解释了 FileShare 概念。
关于.net - 如何使用 .net StreamReader 打开已打开的文件?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/897796/
文档只是说 ReadBlock 是 “Read 的阻塞版本” 但这意味着什么? 之前有人问过这个问题,嗯? http://www.pcreview.co.uk/forums/thread-138578
我对 StreamReader 类的两个不同构造函数有点困惑,即 1.StreamReader(流) 我知道它需要流字节作为输入,但相应的输出是相同的。 这是我使用 StreamReader(Stre
我试图从一个文本文件中读取,该文本文件在写入时有多个输出,但是当我想从我已经输出内容的文本文件中读取时,我想选择最后一个条目(记住每个条目当写作有 5 行时,我只想要包含“密文:”)的行 但是它正在读
我正在开发一个接受TCP连接并读取数据的应用程序,直到读取标记,然后将该数据写入文件系统。我不想断开连接,我想让客户端发送数据来做到这一点,以便他们可以在一个连接中发送多个文件。 我在外部循环中使用了
我尝试制作一个脚本,该脚本可以逐行读取 TXT 文件,并根据里面的内容更改标签。有没有办法检查正在读取哪一行? 最佳答案 此示例使用 StreamReader 类的 ReadLine 方法将文本文件的
我正在尝试处理文本文件的一部分,并使用 UploadFromStream 将文本文件的其余部分写入云 blob。问题在于 StreamReader 似乎从底层流中获取了太多内容,因此后续写入不会执行任
某处是否有非缓冲流读取器实现? 我通过以下方式创建了我的流 FileInputStream inputStream = new FileInputStream(inputFilename); Coun
我想要一个 string[]分配了一个 StreamReader .喜欢: try{ StreamReader sr = new StreamReader("a.txt"); do{
我想弄清楚如何标记文本文件的 StreamReader。我已经能够将这些行分开,但现在我正试图弄清楚如何通过制表符分隔符来分解这些行。这是我目前所拥有的。 string readContents; u
我正在使用我编写的一些不是最佳的代码...:-| 我有以下代码: string fmtLine = ""; string[] splitedFmtLine;
我正在尝试从我的 Web 应用程序的 App_Data 文件夹加载文件: KezMenu kmenu = new KezMenu("~/App_Data/Menu.xml"); 但出于某种原因,这
我正在尝试使用接收 FileStream 的 StreamReader 读取文件的内容。该文件内部有一些空格(字符 32),StreamReader 将它们读取为 0(字符 48)。屏幕截图显示了 F
我有一些奇怪的问题(对我来说)。 有一个应用程序是 Windows 窗体应用程序“firstapp.exe”。还有另一个应用程序也是 Windows 窗体应用程序“launcher.exe”。并且有一
我需要在 C# 应用程序上同时逐行读取四个非常大 (>2 Gb) 的文件。我使用了四种不同的 StreamReader 对象及其 ReadLine() 方法。 同时从四个文件中读取行时,性能会受到严重
我有一个包装在 System.IO.StreamReader 中的输入流...我希望将流的内容写入文件(即 StreamWriter)。 输入流的长度未知。长度可以是几个字节,也可以是千兆字节。 怎么
我对这篇文章有类似的要求... Populate Gridview at runtime using textfile 我想用 StreamReader 读取文本文件并用文件中的数据填充 DataTa
我应该使用哪种编码来读取 æ、Ø、å、ä、ö、ü 等? 最佳答案 您应该使用原始数据的任何编码。你从哪里获取数据,你有关于它的编码的信息吗?如果您尝试使用错误的编码来读取它,您将得到错误的答案:即使您
你好,我在为 Unity3D 编写编辑器时遇到了问题,我遇到了一个问题,我正在从具有常规字符串的 .txt 文件中读取行,然后在每个常规字符串下方读取文件扩展名(代表扩展名的类别) ).当我尝试在分配
这是我的代码: StreamReader reader = new StreamReader("war.txt"); string input = null; while ((input = read
我正在制作一个函数,它将从 StreamReader 中获取行数,不包括注释(以“//”开头的行)和新行。 这是我的代码: private int GetPatchCount(StreamReader
我是一名优秀的程序员,十分优秀!