C# DataTable转化为string

Jakey_Ch 2014-07-07 04:32:44
从SQL查询到数据DataTable,大致如下:

下面的txt为想要得到的字符串
该怎么来写呢?
规则说明:
有个学科数组:
string[] ObjectList = {"语文", “数学”, “英语”};  // 实际上很多项

1、属于学科数组的字段按照(考点::字段)的方式显示,
2、不属于的只显示一次
3、有可能有字段为空,为空的字段直接忽略


public string DataTableToString(DataTable dt, string[] ObjectList)

自己写了下,很繁琐,还没写对~如何来做呢?万分感谢!
...全文
723 8 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
於黾 2014-07-07
  • 打赏
  • 举报
回复
contains是LIST自带的方法,不需要自己做函数遍历比较.
Jakey_Ch 2014-07-07
  • 打赏
  • 举报
回复
引用 1 楼 bdmh 的回复:
就是遍历,自己组装,先遍历行,然后遍历该行的cell
引用 2 楼 happy09li 的回复:
这你按自己的要求组装就行了
引用 5 楼 Z65443344 的回复:
哦,忘了NULL的不加,加层判断看值是否NULL就行了.
有空 的话,麻烦帮忙看看~ 我觉得我这样写的话,如果前缀字段在后面 的话,是不是会有一部分或者全部都没有前缀? 还有,我觉得我写的真的是很繁琐额~~
Jakey_Ch 2014-07-07
  • 打赏
  • 举报
回复
这是我自己写的,还没去掉重复的,感觉自己写的很不好,希望帮忙改下,或者给出更好的。
/// <summary>
        /// DataTable格式化成目标字符串
        /// </summary>
        /// <param name="dt">SQL查询到的数据</param>
        /// <returns></returns>
        private string DataTableToString(DataTable dt, string[] ObjectList)
        {
            StringBuilder sb = new StringBuilder();

            if (dt.Rows.Count > 0)
            {
                string prefix = String.Empty;
                for (int i = 0; i < dt.Rows.Count; i++)
                {
                    for (int j = 0; j < dt.Columns.Count; j++)
                    {
                        string temp_value = dt.Rows[i][j].ToString();
                        string col_name = dt.Columns[j].ColumnName;
                        if (col_name == "考点")
                        {
                            prefix = temp_value;
                        }
                        if(temp_value != String.Empty)
                        {
                            if(IsContain(col_name, ObjectList))
                            {
                                sb.Append(prefix);
                                sb.Append("::");
                                sb.Append(col_name);
                                sb.Append("=");
                                sb.Append(temp_value);
                                sb.Append("\n");
                            }
                            else
                            {
                                sb.Append(col_name);
                                sb.Append("=");
                                sb.Append(temp_value);
                                sb.Append("\n");
                            }
                        }
                    }
                }
            }
            return sb.ToString();
        }

        /// <summary>
        /// 判断字符串是否在数组中
        /// </summary>
        /// <param name="item">字符串</param>
        /// <param name="MesKeyList">字符串列表</param>
        /// <returns>存在返回True</returns>
        private bool IsContain(string item, string[] TestList)
        {
            foreach (string key in TestList)
            {
                if (key == item)
                {
                    return true;
                }
            }
            return false;
        }
於黾 2014-07-07
  • 打赏
  • 举报
回复
哦,忘了NULL的不加,加层判断看值是否NULL就行了.
於黾 2014-07-07
  • 打赏
  • 举报
回复
使用2重for循环搞定,不用定义什么学科数组
List<string> L=new List<string>();
for(int r=0;r<dt.rows.count;r++)
{
if(!L.contains(dt.rows[i][1].Tostring()+dt.rows[i][2].Tostring())
{
L.Add(dt.rows[i][1].Tostring()+dt.rows[i][2].Tostring())

str+=dt.columns[1].columnName+"="+dt.rows[i][1]+"\n";
str+=dt.columns[2].columnName+dt.rows[i][2]+"\n";
}
for(int l=4;l<dt.columns.count;l++)
{
str+=dt.rows[i][3]+"::"+dt.columns[l].columnName+"="+dt.rows[i][l]+"\n";
}
}
  • 打赏
  • 举报
回复
这个,循环输出不就OK了 for(int i=0;i<dt.rows.count;i++) { write2txt("名字="+dt.rows[i]["姓名"].tostring()); write2txt("年龄="+dt.rows[i]["年龄"].tostring()); write2txt("考点::"+dt.rows[i]["考点"].tostring()+"语文"+dt.rows[i]['语文'].tostring()); }
熙风 2014-07-07
  • 打赏
  • 举报
回复
这你按自己的要求组装就行了
bdmh 2014-07-07
  • 打赏
  • 举报
回复
就是遍历,自己组装,先遍历行,然后遍历该行的cell

111,097

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • AIGC Browser
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

试试用AI创作助手写篇文章吧