- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个文件,我将其流式传输到列表对象中以保存到数据库中的临时文件中,因为我必须使用临时表中的数据连接到其他表以获得最终结果,然后将此最终结果导出到.csv 文件。
除了原始文件的流读取外,一切正常。
该文件以逗号分隔且结构非常具体,并且结构永远不会改变。
我遇到的问题是:
“AccountHolder”字段在组成字符串的字符之间有一个逗号,因此我的 FileStream 将其视为分隔符。如何在不破坏 FileStream 必须遵守的逗号分隔符的情况下替换 AccountHolder 字符串中的逗号?
List<object[]> fileContent = new List<object[]>();
using (FileStream reader = File.OpenRead(ofd.FileName))
using (TextFieldParser parser = new TextFieldParser(reader))
{
parser.TrimWhiteSpace = true;
parser.Delimiters = new[] { "," };
parser.HasFieldsEnclosedInQuotes = true;
while (!parser.EndOfData)
{
object[] line = parser.ReadFields();
fileContent.Add(line);
lstRegNo.Add(line[0].ToString().Trim());
lstAccHolder.Add(line[1].ToString().Trim().Replace(',', ' '));
lstAmount.Add(line[2].ToString().Trim().Replace(',', ' '));
lstAccNo.Add(line[3].ToString().Trim());
lstBranch.Add(line[4].ToString().Trim());
lstDate.Add(line[5].ToString().Trim());
lstCode.Add(line[6].ToString().Trim());
lstOrphenColumn.Add(line[7].ToString().Trim());
}
这是我正在流式传输的文件示例:
000001,A WHATEVER,00000000001,0000000000001,000001,160510,17,0
000002,B WHATEVER,00000000002,0000000000002,000002,160510,17,0
000003,C, WHATEVER,00000000003,0000000000003,000003,160510,17,0
000004,D WHATEVER,00000000004,0000000000004,000004,160510,17,0
000005,E WHATEVER,00000000005,0000000000005,000005,160510,17,0
如您所见,在第 3 行,AccountHolder 的姓名中有一个逗号。我需要这个值是“C WHATEVER”,而不是“C, WHATEVER” 我想消除那个逗号但仍然能够将文件流式传输到我的列表中对象用逗号分割文件中的字段。
请注意,每次我收到该文件的数据都会有所不同,因此简单地寻找一个静态值不会削减它。
我该怎么做?
最佳答案
嗯...如果字段是固定的,那么您就没有正确设置您的解析器。它知道如何处理固定宽度的字段,这与规范的 CSV 文件有些不同。
顺便说一句,我倾向于创建一些常量来反射(reflect)“列”的名称:
//--> indexes into parsed line...
const int RegNo = 0;
const int AcctHolder = 2;
const int Amount = 4;
const int AcctNo = 6;
//--> ...etc.
using Microsoft.VisualBasic.FileIO;
//...
List<object[]> fileContent = new List<object[]>();
using (FileStream reader = File.OpenRead(ofd.FileName))
using (TextFieldParser parser = new TextFieldParser(reader))
{
parser.TextFieldType = FieldType.FixedWidth;
parser.SetFieldWidths
(
6 1, //--> width of RegNo, width of ignored comma
10, 1, //--> width of AcctHolder, width of ignored comma
10, 1, //--> width of Amount, width of ignored comma
13, 1, //--> etc...
6, 1,
6, 1,
2, 1,
1
);
while (!parser.EndOfData)
{
object[] line = parser.ReadFields();
fileContent.Add(line);
lstRegNo.Add( line[ RegNo ].ToString( ));
lstAccHolder.Add(line[ AcctHolder ].ToString().Replace(',', ' '));
lstAmount.Add(line[ Amount ].ToString().Trim().Replace(',', ' '));
lstAccNo.Add(line[ AcctNo ].ToString().Trim());
//--> etc...
}
}
更多信息,查看this出。
关于c# - 替换逗号分隔文件中的特定逗号,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37525159/
我正在尝试从下拉列表中创建一个多选复选框,并通过 ; 连接所选结果。 我的代码是这样的: var myobject = { ValueA : 'Text A', ValueB : 'T
我有输入,我需要获取值并用 “|” 符号分隔。 我的输入: 输出我需要的: 00:00|00:00|00:00 我的代码是: (而且它不工作) var timesArray = $('table').
我正在尝试将超过 400 万行的列拆分为 4 个新列,问题是我不知道在哪里查看或我应该使用 Google 搜索哪个术语。 (是的,我已经在 Google 和 Stack 中搜索了一个类似的问题,但只在
我有一个很大的 csv 文件,其中充满了用“|”分隔的数字字符,例如: 432452 | 543634 4122442 | 41256512 64523 | 12416 然后我读入数据如下: fs
我有一个程序可以计算多个数字的阶乘。这些数字在 cmd 中作为参数传递: factorial.exe 3 4 5 这将分别计算 3、4 和 5 的阶乘。该程序的早期版本有一个百分比显示堆栈的完整性。我
这个问题已经有答案了: 奥 git _a (6 个回答) 已关闭 9 年前。 我有一个双数“547.123456” 我只想使用这个 double 作为“547.1”,就像“.”后面只有 1 个数字 我
我有一个程序可以计算多个数字的阶乘。这些数字在 cmd 中作为参数传递: factorial.exe 3 4 5 这将分别计算 3、4 和 5 的阶乘。该程序的早期版本有一个百分比显示堆栈的完整性。我
我有一个 ArrayList,其中包含一个 messageId、一个 -、一个用户名。 示例:E123-sam 我想划分 List 的每个元素,使得 - 之前的部分进入一个 ArrayList ,而之
我目前有一个“日期”列作为 pandas 数据框的索引,其格式为: January February .... Year2 January February ... Year3 (它来自 pdf 表格
我正在尝试对我的 .mdb 数据库进行 ODBC 查询。我正在使用 mdbtools 驱动程序。该代码是使用 Eclipse 用 C 语言编写的。唯一的问题是,当我写例如: "SELECT 'last
我需要知道如何将这两个if else 部分分开。 public static int NextBday(int Bdays, int days){ int daysleft = 0;
我想计算我的员工分开但合并在一起的出勤率 My target output 我的代码 SELECT count(employees_id) as numbers FROM attendance WH
关闭。这个问题需要details or clarity .它目前不接受答案。 想改进这个问题吗? 通过 editing this post 添加细节并澄清问题. 关闭 7 年前。 Improve t
下面是我的代码的一小段摘录,它从 API 添加了一行。总共有很多行。 每一行包含一行数据如 TY8tr,50,34,P,SB, 数据行在数据类型上是一致的。我如何通过 ,'s 拆分数组列表中
我想获取选中的元素并用逗号分隔它们,最后一个元素用“and”分隔 它的显示输出为: 我想删除最后一个元素后面的逗号 (,) 并在它前面添加 'and',例如 Sugar, Milk and Extra
我是 JSON 的新手,但在从已解析的 JSON 对象中提取数据时遇到问题: 我有一个 getstats.php 文件,它回显 mysql 查询的 json 编码结果。以下是 php 文件返回的示例:
我有一个像这样的数字/字符串(我不确定如何将 int 与字符串相互转换) 000000122310200000223340000700012220000011411000000011011271043
标签内的文本
我想尝试一些基本的网络抓取,但遇到了一个问题,因为我习惯了简单的 td-tags,在这种情况下,我有一个网页,其中包含以下预标记和其中的所有文本,这意味着刮掉它有点棘手。 11111111 1111
出于练习目的,我正在开发 TCP 客户端/服务器系统,我想在两者之间发送特定数据。 我已经能够发送字节并让它们显示为字符串。此外,我还可以发送一个特定的字符串(“mb”)并在服务器端弹出一个 Mess
在大量的 unicode 字符中,有一些实际上表示多个字符,例如两个 'f' 字符的 U+FB00 连字 ff。有什么方法可以轻松地将这样的字符转换为多个单个字符?最好是标准 Java API 中可用
我是一名优秀的程序员,十分优秀!