gpt4 book ai didi

c# - 通过 CSV 查找具有特定标题的列

转载 作者:太空宇宙 更新时间:2023-11-03 11:21:59 24 4
gpt4 key购买 nike

我正在开发一个程序,您可以从 csv 文件中选择一个标题(它最初会解析标题),我希望用户能够获取列的数据而不必读取整个文件。(制作一个字符串数组列表,并提取字符串数组索引以获取信息,这是简单易行的事情)。

有没有一种方法可以使用 seek 来做到这一点?也许搜索一个字符串(这将是标题)并在其列中获取信息。

这是 getHeader 函数,以防它有帮助...

private string[] getHeader(string path)//gets the headers from the file path specified.
{
List<string> row = new List<string>();

using (StreamReader readFile = new StreamReader(path))
{
row = (readFile.ReadLine().Split(',').ToList());
}

return row.ToArray();

}

(to list 和 to array 只是为了解决最初设置数组大小的问题......)

谢谢!

最佳答案

不可能。

Seek 可以定位到文件中的某个确定位置。如果您的固定长度记录 (SDF/COBOL) 文件具有巨大的记录长度和很少的记录,这将是一个不错的主意。

不幸的是,根据定义,.csv 是可变长度记录。您只能根据击中记录末尾的 cr/lf 来判断一条记录的停止和开始位置。

即使对于大多数固定记录格式,这也不是一个好主意。由于缓冲,操作系统无论如何都会读取整个文件,因为您可能会提前寻找比操作系统预加载的更小的数量。

我明白您为什么要这样做;直觉上,这听起来会更快。虽然您应该始终在设计代码时考虑到速度,但这是低级的,足以被称为“过早优化”——谷歌搜索。基本上,您必须通过编写它来向自己证明它运行缓慢,然后,当您发现它对功能造成巨大障碍时,您可以进行优化。

不要自己解析!

MS 有一个组件。 Microsoft.VisualBasic.FileIO.TextFieldParser。是的,您可以将它与 C# 一起使用(即使下面的示例是在 VB 中,您也可以弄清楚您需要做什么)。不要因为包含对 VB 的引用而感到骄傲。你口袋里的时间和金钱很重要,不能说,'我不会用 10 英尺的杆子碰任何 VB'。更改是程序集已经在您的目标 PC 上。唯一需要担心的是,如果您有程序安装包下载大小问题,或者正在部署到非 PC 平台。

    Using Reader As New Microsoft.VisualBasic.FileIO.TextFieldParser(CSVPath)

Reader.TextFieldType = Microsoft.VisualBasic.FileIO.FieldType.Delimited
Reader.Delimiters = New String() {","}
Reader.TrimWhiteSpace = True
Reader.HasFieldsEnclosedInQuotes = True

While Not Reader.EndOfData
Try
Dim st2 As New List(Of String)
st2.addrange(Reader.ReadFields())
If iCount > 0 Then ' ignore first row = field names
Dim p As New clsPerson
p.CSVLine = st2
While p.CSVLine.Count < 15
p.CSVLine.Add("")
End While
p.FirstName = st2(1).Trim
If st2.Count > 2 Then
p.MiddleName = st2(2).Trim
Else
p.MiddleName = ""
End If
p.LastNameSuffix = st2(0).Trim
If st2.Count >= 6 Then
p.TestCase = st2(5).Trim
End If
If st2(3) > "" Then
p.CertsFromCase.Add(st2(3))
End If
cases.Add(p)
Else
stFirstRow = CatLine(st2.ToArray)
Dim st3(6) As String
For kk As Integer = 0 To Math.Min(st2.Count - 1, 5)
st3(kk) = st2(kk)
Next
If 0 = InStr(st3(0), "Last Name", CompareMethod.Text) Or _
0 = InStr(st3(1), "First Name", CompareMethod.Text) Or _
0 = InStr(st3(2), "Middle Name", CompareMethod.Text) Or _
0 = InStr(st3(3), "Policy", CompareMethod.Text) Or _
0 = InStr(st3(5), "Test Case", CompareMethod.Text) Then
stFirstRow = "Last Name,First Name,Middle Name,Policy,,Test Case #" & vbCrLf & stFirstRow
End If
End If
Catch ex As Microsoft.VisualBasic.FileIO.MalformedLineException
MsgBox("Line " & ex.Message & " is not valid and will be skipped.")
End Try
iCount += 1
End While
End Using

关于c# - 通过 CSV 查找具有特定标题的列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10637797/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com