我有一个包含所有数据库名称的List
。我需要在控制台中显示该列表中包含的项(使用Console.WriteLine()
)。我该如何实现此目标?
我有一个包含所有数据库名称的List
。我需要在控制台中显示该列表中包含的项(使用Console.WriteLine()
)。我该如何实现此目标?
ForEach
方法,并且你可以将Console.WriteLine
作为方法组传递。编译器会使用隐式转换将方法组转换为,在本例中是Action<int>
,并从组中选择最具体的方法,在本例中是Console.WriteLine(int)
。 var list = new List<int>(Enumerable.Range(0, 50));
list.ForEach(Console.WriteLine);
也适用于字符串 =)
如果要极端追究(我并不建议修改您的答案 - 只是为了有趣的评论),Console.WriteLine
是一个方法组。 然后编译器使用从方法组到 Action<int>
的隐式转换,选择最特定的方法(在此情况下为Console.WriteLine(int)
)。
虽然使用 List<T>.ForEach
的答案非常好,但我发现 String.Join<T>(string separator, IEnumerable<T> values)
方法更有用。
例如:
List<string> numbersStrLst = new List<string>
{ "One", "Two", "Three","Four","Five"};
Console.WriteLine(String.Join(", ", numbersStrLst));//Output:"One, Two, Three, Four, Five"
int[] numbersIntAry = new int[] {1, 2, 3, 4, 5};
Console.WriteLine(String.Join("; ", numbersIntAry));//Output:"1; 2; 3; 4; 5"
备注:
如果分隔符为null,则使用空字符串(String.Empty
)代替。如果values的任何成员为null,则使用空字符串代替。
Join(String, IEnumerable<String>)
是一个方便的方法,它允许您在不先将元素转换为字符串数组的情况下连接IEnumerable(Of String)集合中的每个元素。它特别适用于语言集成查询(LINQ)查询表达式。
这对于该问题应该可以正常工作,而对于其他具有数组值的问题,请使用此同一方法的其他重载,String.Join Method (String, Object[])
参考: https://msdn.microsoft.com/en-us/library/dd783876(v=vs.110).aspx
ToString
方法:public void WriteToConsole(IEnumerable items)
{
foreach (object o in items)
{
Console.WriteLine(o);
}
}
Console.WriteLine(object)
,因此它会和在这种情况下使用 foreach
一样装箱。编辑:使用 List<T>.ForEach
的答案非常好。如果您有任意序列(例如 LINQ 表达式的结果),则上述循环更加灵活,但是如果您确实拥有 List<T>
,我认为 List<T>.ForEach
是更好的选择之一。 List<T>.ForEach
的一个优点是,如果您有具体的列表类型,它将使用最适当的重载。例如:List<int> integers = new List<int> { 1, 2, 3 };
List<string> strings = new List<string> { "a", "b", "c" };
integers.ForEach(Console.WriteLine);
strings.ForEach(Console.WriteLine);
Console.WriteLine(int)
,而写出字符串时将使用Console.WriteLine(string)
。如果没有特定的重载可用(或者您只是使用通用的List<T>
且编译器不知道T
是什么),它将使用Console.WriteLine(object)
。Console.WriteLine
作为方法组的使用。这比使用lambda表达式更简洁,实际上稍微更有效率(因为委托将只是调用Console.WriteLine
,而不是调用一个方法,该方法再调用Console.WriteLine
)。Person
类中重写ToString
方法。 - Jon Skeet你也可以使用List的内置foreach,例如:
List<T>.ForEach(item => Console.Write(item));
这段代码运行速度也显著地更快!
以上代码还使您能够操作Console.WriteLine,例如:
List<T>.ForEach(item => Console.Write(item + ",")); //Put a,b etc.
Console.WriteLine(string.Join<TYPE>("\n", someObjectList));
List<Team_Details> teamDetails = new List<Team_Details>();
然后您可以连接到数据库并执行数据检索部分,将其保存到列表中,如下所示。
string connetionString = "Data Source=.;Initial Catalog=your DB name;Integrated Security=True;MultipleActiveResultSets=True";
using (SqlConnection conn = new SqlConnection(connetionString)){
string getTeamDetailsQuery = "select * from Team";
conn.Open();
using (SqlCommand cmd = new SqlCommand(getTeamDetailsQuery, conn))
{
SqlDataReader rdr = cmd.ExecuteReader();
{
teamDetails.Add(new Team_Details
{
Team_Name = rdr.GetString(rdr.GetOrdinal("Team_Name")),
Team_Lead = rdr.GetString(rdr.GetOrdinal("Team_Lead")),
});
}
然后你可以在命令提示符中按如下方式打印此列表。
foreach (Team_Details i in teamDetails)
{
Console.WriteLine(i.Team_Name);
Console.WriteLine(i.Team_Lead);
}
List<string> names = new List<string> { "One", "Two", "Three", "Four", "Five" };
for (int i = 0; i < names.Count; i++)
{
Console.WriteLine(names[i]);
}