将写行重复的行写入文件

时间:2016-10-11 23:48:44

标签: c# sql datatable streamwriter

我很难过。我有一个来自3个数据表的数据被写入文本文件,但是当我在文件中写入某个表格时,它会写出重复的内容,而我无法弄清楚原因。

这是写入文件的代码

        public void writeCharge2(StreamWriter sw, string dos1, int i)
    {
        getCharges(dos1, SqlCon);
        foreach (DataRow row in chargeTable.Rows)
        {
            for (int n = 0; n <= chargeTable.Rows.Count -1; n++)
            {                    
                ChargeLine = chargeTable.Rows[n][0].ToString();

                writeCharge(sw, dos1, i, ChargeLine);
                sw.WriteLine();
                payChart.Reset();
                payGraph.Reset();
            }

        }
        chargeTable.Reset();
    }

    public void writeCharge(StreamWriter sw, string dos2, int i, string CPTLine)
    {
        getPayments(ChargeLine, SqlCon, dos2);
        string description = getDesc(CPTLine, SqlCon);
        sw.WriteLine("   Description: " + CPTLine + " - " + description);
        sw.WriteLine("-----------Payments-----------");

        if (i < payGraph.Rows.Count)
        {
            foreach (DataRow row in payGraph.Rows)
            {
                for (i = 0; i < row.ItemArray.Length -1; i++)
                {
                    DateTime payDate = Convert.ToDateTime(payGraph.Rows[i][0].ToString());
                    string payDate1 = payDate.ToString("MM/dd/yyyy");
                    decimal money = Convert.ToDecimal(payGraph.Rows[i][1].ToString());
                    string money1 = money.ToString("C");
                    string payer = payGraph.Rows[i][2].ToString();

                    sw.Write("Payment Date: " + payDate1 + " | ");
                    sw.Write("Amount: " + money1 + " | ");
                    sw.Write("Payer: " + payer);
                    sw.WriteLine();
                }

                sw.WriteLine();
            }
        }

    }

        public void writeData(StreamWriter sw)
    {
        clearTables();
        getDos(SqlCon);
        int i = 0;

        foreach(DataRow row in servicetable.Rows)
        {
            string dosNow = Convert.ToString(servicetable.Rows[i][0]);

            setupPat(sw, i);
            writeCharge2(sw, dosNow, i);
            sw.WriteLine(Environment.NewLine);
                i++;

        }

以下是如何将其写入文件,您可以看到正在写的重复行

服务日期:08/22/2012
   描述:76775 - 美国RETROPERITONEAL LIMITED
----------- -----------付款
付款日期:09/10/2012 |金额:23.14美元|付款人:保险 付款日期:09/24/2012 |金额:5.78美元|付款人:保险
付款日期:09/10/2012 |金额:23.14美元|付款人:保险 付款日期:09/24/2012 |金额:5.78美元|付款人:保险

   描述:93922 - 极端非侵入性1或2级别 ----------- -----------付款
付款日期:09/10/2012 |金额:9.74美元|付款人:保险 付款日期:09/24/2012 |金额:2.43美元|付款人:保险

付款日期:09/10/2012 |金额:9.74美元|付款人:保险 付款日期:09/24/2012 |金额:2.43美元|付款人:保险

   描述:76775 - 美国RETROPERITONEAL LIMITED
----------- -----------付款
付款日期:09/10/2012 |金额:23.14美元|付款人:保险 付款日期:09/24/2012 |金额:5.78美元|付款人:保险
付款日期:09/10/2012 |金额:23.14美元|付款人:保险 付款日期:09/24/2012 |金额:5.78美元|付款人:保险

1 个答案:

答案 0 :(得分:1)

这是因为writeCharge2函数中不需要foreach循环。您使用foreach迭代行,然后在每次迭代中打印所有行,因此对于2行,它们将被打印两次,3行 - 3次等。