我很难过。我有一个来自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美元|付款人:保险
答案 0 :(得分:1)
这是因为writeCharge2函数中不需要foreach
循环。您使用foreach
迭代行,然后在每次迭代中打印所有行,因此对于2行,它们将被打印两次,3行 - 3次等。