C#文件操作的几个小坑

工作需要,这几天需要做一些数据导出到CSV文件的工作。翻出以前的文件操作代码,过程中遇到了之前没有遇到过的问题,这里记录一下。

主要遇到的问题就是两个,一个是导出CSV文件时的分隔符(英文逗号)的处理,会出现结果与目的不一致的问题,第二个就是文件组织及输出的效率问题。

1、CSV分隔符问题,网上有一堆的文章介绍,实际情况还是要自己搞懂。自己还是特意手撸了一些实验代码。基本上跟一些注意事项一样。这里只说结果,就不附上代码了。

        如果要输入的数据要保留英文逗号,需要用双引号符号把目的数据包起来,做成字符串数据导出。举例:

        string dataA = "i can do, anything for you.";

        string dataB = "456";

 想要保证dataA的数据导出后,用Excel打开时不被分开,这里做如下处理。

         dataA = string.Format("\"{0}\"", dataA);

这样包起来即可。输出后,用Excel打开时,就不会被认为是两个数据了。还有一个就是如果dataA中本来就有英文的双引号,导出是没有问题,但用Excel打开后,就看不到双引号了。还想保留双引号在Excel单元格里的显示。那就需要在使用双引号符号包住数据前,再多做一个处理,这个处理如下:

        string dataA = "\" i can do, anything for you.\"";

        string dataA = dataA.Replace("\"", "\"\"");

        dataA = string.Format("\"{0}\"", dataA);

这样就可以既保留原本需要保留的双引号,又不会打开时分割成两个数据了。各位可以自行手撸几行代码看看。这里就不展开了。

2、输出文件组织时,运行效率不高。都知道文件输出时或者写文件时,基本上都会调用

        stream的write函数,一次性写入文件内容。但是需要在之前整理好文件内容到一个字符串中统一做处理。在这个过程中,字符串越大,后面的处理就越慢。尤其是批量组织文件内容的时候,文件越多,文件越大,这个等待的时间简直令人发指。

        各位可能知道StreamWriter这个类,它带有一个WriteLine的函数,可以按行输出文件。只是需要将输出的文件整理到数组或者list里。没什么可说的。这里记录一下,算是给自己的一个交代

        

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
C#文件操作中的相对路径是指相对于当前工作目录的路径。当前工作目录是指程序运行时所在的目录。在C#中,可以使用System.IO.Path类的一些方法来处理文件路径操作。具体来说,可以使用Path类的Combine方法来拼接路径,使用GetDirectoryName方法来获取路径的目录部分,使用GetFileName方法来获取路径的文件名部分,使用GetExtension方法来获取路径的扩展名部分等等。 举个例子,假设当前工作目录是"D:\MyProject",而需要操作文件在该目录下的"Data"文件夹中的"sample.txt"文件。那么可以使用Path类的Combine方法来拼接路径,代码如下: string filePath = Path.Combine("Data", "sample.txt"); 这样就得到了相对路径"Data\sample.txt"。在进行文件操作时,可以使用这个相对路径来指定要操作文件。 需要注意的是,相对路径是相对于当前工作目录的,所以在不同的环境下,当前工作目录可能会有所不同。为了确保代码的可移植性,可以使用Path类的GetFullPath方法来获取完整的路径,代码如下: string fullPath = Path.GetFullPath(filePath); 这样就可以获取到"D:\MyProject\Data\sample.txt"这个完整的路径,无论当前工作目录是什么。 综上所述,C#文件操作中的相对路径是相对于当前工作目录的路径。可以使用Path类的一些方法来处理文件路径操作,如拼接路径、获取目录部分、获取文件名部分等。在进行文件操作时,可以使用相对路径来指定要操作文件。为了确保代码的可移植性,可以使用GetFullPath方法来获取完整的路径。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [浅析C#文件路径的操作](https://download.csdn.net/download/weixin_38715097/12790167)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [C#操作文件系统绝对路径和相对路径](https://download.csdn.net/download/zhwcd/10670331)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [C#中winform使用相对路径读取文件的方法](https://download.csdn.net/download/weixin_38660069/13991652)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值