- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在开发一个程序,您可以从 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/
我附上了一个我尝试使用 html/css 实现的示例(如果您看不到图像:名字和姓氏,然后第二行是职位描述)。我希望所有文本(两行)在一个 div 中强制对齐(左和右),但我不确定这是否可能。我尝试了一
我想使两个 h1 元素成为 div 上的标题/页眉。所以每个都在特定的 div 之上。 Youtube Achievements
我想让每个 EditText 对象都有自己的标题,就像 Pure Android 指南中那样 (screenshot) 这个东西有原生支持吗?我想他们也可能会使用带有部分的 ListView ,但这对
是否可以像 UITableView headerView 一样创建 UICollectionView 标题 View ?我的意思是整个集合 View 的标题 View ,而不是每个部分的重复 View
我一直在遵循有关排版的 Google 官方 Material 设计指南 (http://www.google.com/design/spec/style/typography.html),但我发现它们
我目前正在尝试找到可以帮助我从视频文件中提取元数据或信息的 python 库,例如 [ mp4, Mkv, Avi, WebM, mpg ] 格式为例。 我主要从视频文件中提取的主要数据是 [标题、描
你好, 这是我正在尝试做的: 将每个缩略图的内容(img + 标题)居中。我的 img 必须是 span3,标题必须是 span4。 这是我的问题: 我可以获取内容中心,或者标题 float 在 im
我有一个带有导航栏的应用程序,可以从一个 View Controller 导航到下一个 View Controller 。在某些模拟器和设备上导航到下一个 View Controller 时,后退按钮
我遇到了一些非常酷的 t-sql,可以从一个 t-sql 查询中的选定行生成一个逗号分隔的列值列表: SELECT @MyList = ISNULL(@MyList,'') + Title + ',
请确保将 HTML heading 标签只用于标题。不要仅仅是为了生成粗体或的文本而使用标题。 搜索引擎使用标题为您的网页的结构和内容编制索引。 因为用户可以通过标题来快速浏览您的网页,所以用标
我正在使用 wkhtmltopdf 将 html 转换为 pdf。 我想在每个页面中添加标题,但它只显示在第一页(目录)中。 我使用的命令是 "C:\Program Files\wkhtmltopdf
如何使用 ggplot2 显示观察的方向(标题)?有没有办法调整shape=17 (三角形)以便它“指向”下一次观察? 示例代码 library(ggplot2) dat % pivot_wide
我尝试在 cocoa 应用程序中显示/隐藏标题栏。我使用以下代码: if ([window styleMask]==NSResizableWindowMask) { [wind
我有这样的 HTML 标题 http://s1.postimg.org/4ebyk3qwv/image.png 当我编写这段代码时: document.getElementById("TL85_1_
我叫麦克。谢谢你的帮助。 在Wordpress中,我们已经设计了我们的网站,以便在Facebook调试器中og数据尽可能接近youtube。尽管如此,在Facebook上共享视频的方式还是不同的。尽管
从 web 应用程序的客户端,我点击了服务器端路由,它只是第三方 API 的包装器。使用分派(dispatch),我试图让服务器端请求返回 exact header 和第三方 API 对客户端 AJA
从 web 应用程序的客户端,我点击了服务器端路由,它只是第三方 API 的包装器。使用分派(dispatch),我试图让服务器端请求返回 exact header 和第三方 API 对客户端 AJA
我是 SAPUI5 的新手,在导航、侧边栏和标题方面遇到一些问题。我想开发一个带有标题和侧边栏的应用程序。我为此使用“ToolPage”。每个页面都包含工具页,如下所示:
我最近在为客户做的项目中被介绍给Go。他们已经建立了代码库,需要进行一些更改。 我注意到所有的方法,结构等等都有一些奇怪的类似于标题的注释,如下所示: // SomeType ... type Som
我创建了一个采用整个屏幕布局的标题布局(xml 文件)... 我还创建了一个 listView 并将此 header_layout 添加到 listView 中: LayoutInflater inf
我是一名优秀的程序员,十分优秀!