static List<GISVertex> ReadMultipleVertexes(StreamReader sr) { List<GISVertex> vs = new List<GISVertex>(); int vcount = Convert.ToInt32(sr.ReadLine()); for (int vc = 0; vc < vcount; vc++) vs.Add(new GISVertex(sr)); return vs; }
时间: 2024-02-14 09:35:18 浏览: 120
这个函数是用来读取多个顶点坐标的,其中包含了多个 `GISVertex` 对象。根据代码,我可以看到函数首先读取一个整数 `vcount`,该整数表示要读取的顶点数量。接下来,函数使用一个 for 循环读取 `vcount` 个顶点坐标,并将它们添加到一个 `GISVertex` 对象列表中。
如果你遇到了 "输入字符串的格式不正确" 的错误提示,那么很可能是因为输入的顶点坐标格式不正确。具体来说,可以检查一下输入的字符串是否符合程序所期望的格式。在这个函数中,每个顶点的坐标是由一个 `GISVertex` 对象的构造函数读取的,因此你需要确保输入的字符串可以被正确地解析为一个 `GISVertex` 对象。
如果你仍然无法解决问题,建议你检查一下输入的数据是否完整、正确,并且符合程序的要求。你还可以在代码中添加一些错误处理逻辑,例如在遇到无法解析的字符串时,输出一些有用的错误信息,帮助你更好地定位问题所在。
相关问题
public List<List<string>> GetDataCSV(string path) { string pattern = @"\d+"; List<List<string>> data = new List<List<string>>(); using(StreamReader sr = new StreamReader(@path, Encoding.GetEncoding("GB2312"))) { string nextline; MatchCollection myMatches; while((nextline = sr.ReadLine()) != null ) { myMatches = Regex.Matches(nextline, pattern); List<string> rowdata = new List<string>(); ; foreach(Match nextmatch in myMatches) { rowdata.Add(nextmatch.Value); } data.Add(rowdata); } //消除最后的空行 for(int i=data.Count-1;i>=0;i--) { if(data[i].Count ==0) { data.Remove(data[i]); } else { break; } } } return data; }解释每局什么意思
这段代码是一个 C# 函数,用于读取指定路径下的 CSV 文件,并将其中的数据以 List<List<string>> 的形式返回。下面是对这个函数的逐行解释:
```csharp
public List<List<string>> GetDataCSV(string path)
{
string pattern = @"\d+"; // 正则表达式,用于匹配数字
List<List<string>> data = new List<List<string>>(); // 创建二维 List,用于保存 CSV 中的数据
// 使用 StreamReader 打开指定路径下的文件
using (StreamReader sr = new StreamReader(@path, Encoding.GetEncoding("GB2312")))
{
string nextline; // 用于存储下一行的文本内容
MatchCollection myMatches; // 用于存储正则表达式匹配结果的集合
// 循环读取文件中的每一行
while ((nextline = sr.ReadLine()) != null)
{
// 使用正则表达式匹配当前行中的所有数字,并将它们添加到一个 List<string> 中
myMatches = Regex.Matches(nextline, pattern);
List<string> rowdata = new List<string>(); ;
foreach (Match nextmatch in myMatches)
{
rowdata.Add(nextmatch.Value);
}
// 将当前行的数据添加到二维 List 中
data.Add(rowdata);
}
// 消除最后的空行
for (int i = data.Count - 1; i >= 0; i--)
{
if (data[i].Count == 0)
{
data.Remove(data[i]);
}
else
{
break;
}
}
}
// 返回二维 List,其中每个元素都是一个包含数字的字符串 List
return data;
}
```
总体来说,这个函数的作用是读取 CSV 文件并将其中的数字数据保存到一个二维 List 中。具体实现过程如下:
1. 首先,定义一个正则表达式 pattern,用于匹配 CSV 文件中的数字。
2. 创建一个二维 List data,用于保存 CSV 文件中的数据。
3. 使用 StreamReader 打开指定路径下的 CSV 文件。
4. 循环读取文件中的每一行,使用正则表达式匹配当前行中的数字,并将它们添加到一个 List<string> rowdata 中。
5. 将 rowdata 添加到二维 List data 中。
6. 循环结束后,消除最后的空行。
7. 返回二维 List data,其中每个元素都是一个包含数字的字符串 List。
//string goodBarcodeFile = "goodBarcodes.txt"; //string badBarcodeFile = "badBarcodes.txt"; //List<string> goodBarcodeList = new List<string>(); //List<string> badBarcodeList = new List<string>();代码基础上修改,获取本地文件中的良品和不良品条码
好的,你可以按照以下代码来获取本地文件中的良品和不良品条码:
```
using System.IO;
using System.Collections.Generic;
string goodBarcodeFile = "goodBarcodes.txt";
string badBarcodeFile = "badBarcodes.txt";
List<string> goodBarcodeList = new List<string>();
List<string> badBarcodeList = new List<string>();
// 获取良品条码
if (File.Exists(goodBarcodeFile))
{
using (StreamReader sr = new StreamReader(goodBarcodeFile))
{
string line;
while ((line = sr.ReadLine()) != null)
{
goodBarcodeList.Add(line);
}
}
}
// 获取不良品条码
if (File.Exists(badBarcodeFile))
{
using (StreamReader sr = new StreamReader(badBarcodeFile))
{
string line;
while ((line = sr.ReadLine()) != null)
{
badBarcodeList.Add(line);
}
}
}
```
上述代码首先判断了良品和不良品条码文件是否存在,如果存在,则逐行读取文件内容并添加到对应的 List 中。其中,使用了 `StreamReader` 类来读取文件内容。读取完成后,`goodBarcodeList` 和 `badBarcodeList` 分别存储了良品和不良品条码列表。
阅读全文