华域联盟 .Net 使用linq读取分隔符文本文件

使用linq读取分隔符文本文件

如下图:

然后它们存储到文本文件有这样的列:

复制代码 代码如下:

First Name

Last Name

Job Title

City

Country

在我们读取这个文件之前,先建一个实体类:

复制代码 代码如下:

/// <summary>

 /// Customer entity

/// </summary>

public class Customer{

public string Firstname { get; set; }

public string Lastname { get; set; }

public string JobTitle { get; set; }

public string City { get; set; }

public string Country { get; set; }

}

接着我们使用LINQ读取整个文件:

复制代码 代码如下:

var query = from line in File.ReadAllLines(filePath)

 let customerRecord = line.Split(',')

select new Customer()

 {

Firstname = customerRecord[0],

Lastname = customerRecord[1],

 JobTitle = customerRecord[2],

City = customerRecord[3],

Country = customerRecord[4]
};

 foreach (var item in query)

{

Console.WriteLine("{0}, {1}, {2}, {3}, {4}"

 , item.Firstname, item.Lastname, item.JobTitle, item.City, item.Country);

}

要读取可以带条件的记录也可以,我们filter出Country是UK:

复制代码 代码如下:

 var query = from c in

(from line in File.ReadAllLines(filePath)

 let customerRecord = line.Split(',')

select new Customer()

{

Firstname = customerRecord[0],

Lastname = customerRecord[1],

 JobTitle = customerRecord[2],

City = customerRecord[3],

Country = customerRecord[4]
})

 where c.Country == "UK"

select c;

另一例子:

复制代码 代码如下:

var query = from c in

(from line in File.ReadAllLines(filePath)

let customerRecord = line.Split(',')

select new Customer()

{

Firstname = customerRecord[0],

Lastname = customerRecord[1],

JobTitle = customerRecord[2],

City = customerRecord[3],

Country = customerRecord[4]
})

where c.JobTitle.Contains("Sales")

select c;

本文由 华域联盟 原创撰写:华域联盟 » 使用linq读取分隔符文本文件

转载请保留出处和原文链接:https://www.cnhackhy.com/53461.htm

本文来自网络,不代表华域联盟立场,转载请注明出处。

作者: sterben

发表回复

联系我们

联系我们

2551209778

在线咨询: QQ交谈

邮箱: [email protected]

工作时间:周一至周五,9:00-17:30,节假日休息

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

关注微博
返回顶部