如果列不是数字,则从数据表中删除行

Remove row from datatable if column is not numeric

我有一个包含几列的数据表。第一列是我们的员工 ID。不幸的是,并非所有行都是数字的,我们想删除那些不是数字的行。例如,我们有 1 行有“@#$”,我想删除这样的行。我目前有以下代码。

        var len = dt.Rows.Count;
        for(int y = 0; y < len; y++)
        {
            var mwd = dt.Columns[0].ToString();
            bool valid = int.TryParse(mwd, out int n);
            if (valid)
            {
                log.LogInformation("mwd is numeric");
            }
            else
            {
                log.LogInformation("mwd is not numeric");
                dt.Rows[y].Delete();
            }
        }

但是,这不会删除该行。我究竟做错了什么?提前致谢。

编辑:周边代码

DataSet ds = new DataSet();
        DataTable dt = new DataTable();
        string[] columns = { "Mwd", "Naam", "Kostenplaats Externe id (Klant)", "Kostenplaats Loonlijstcode (Activiteit)", "Kostenplaats Naam (Activiteit)", "Datum", "Uren ruw", "Ber. Uren", "Verlof volledig pad" };
        foreach (string column in columns)
        {
            dt.Columns.Add(column);
        }
        using (StreamReader reader = new StreamReader(req.Body))
        {
            while (reader.EndOfStream == false)
            {
                string[] rows = reader.ReadLine().Split(',');
                DataRow dr = dt.NewRow();
                for (int i = 0; i < columns.Length; i++)
                {
                    var temp = rows[i].Trim('"');
                    dr[i] = temp.Trim('\'');
                }
                dt.Rows.Add(dr);
            }
        }

        for (int i = 0; i < dt.Rows.Count; i++)
        {
            foreach (DataColumn column in dt.Columns)
            {
                var mwd = dt.Rows[i][column].ToString();
                int n;
                bool valid = int.TryParse(mwd, out n);
                if (valid)
                {
                    log.LogInformation("mwd is numeric");
                }
                else
                {
                    log.LogInformation("mwd is not numeric");
                    dt.Rows[i].Delete();
                    i--;
                    break;
                }
            }
        }
        dt.AcceptChanges();

        log.LogInformation(dt.ToString());


        for (int x = 0; dt.Rows.Count > x; x++)
        {
            string sql = "INSERT INTO dbo.kronos (Mwd, Naam, KostenplaatsExterneIdKlant, KostenplaatsLoonlijstcodeActiviteit, KostenplaatsNaamActiviteit, Datum, UrenRuw, BerUren, VerlofVolledigPad)" +
                " VALUES ('" + dt.Rows[x]["Mwd"].ToString() + "', '" + dt.Rows[x]["Naam"].ToString() + "', '"
                + dt.Rows[x]["Kostenplaats Externe id (Klant)"].ToString() + "', '" + dt.Rows[x]["Kostenplaats Loonlijstcode (Activiteit)"].ToString() + "', '"
                + dt.Rows[x]["Kostenplaats Naam (Activiteit)"].ToString() + "', '" + dt.Rows[x]["Datum"].ToString() + "', '"
                + dt.Rows[x]["Uren ruw"].ToString() + "', '" + dt.Rows[x]["Ber. Uren"].ToString() + "', '" + dt.Rows[x]["Verlof volledig pad"].ToString() + "')";

            var str = Environment.GetEnvironmentVariable("ConnectionString");

            using (SqlConnection connection = new SqlConnection(str))
            {
                SqlCommand command = new SqlCommand(sql, connection);
                connection.Open();
                command.ExecuteNonQuery();
            }
        }

        return result;

试试这个代码

for (int i = 0; i< dt.Rows.Count;i++)
{
   foreach (DataColumn column in dt.Columns)
   {
       var mwd = dt.Rows[i][column].ToString();
       int n;
       bool valid = int.TryParse(mwd, out n);
       if (valid)
       {
          log.LogInformation("mwd is numeric");
       }
       else
       {
         log.LogInformation("mwd is not numeric");
         dt.Rows[i].Delete();
         i--;
         break;
       }
    }
 }
dt.AcceptChanges();

如果您知道列名称或其索引,请使用以下代码

for (int i = 0; i < dt.Rows.Count; i++)
{
    var mwd = dt.Rows[i]["Name"].ToString();
    //or---------------------------------
    var mwd = dt.Rows[i][index].ToString();
    int n;
    bool valid = int.TryParse(mwd, out n);
    if (valid)
    {
       log.LogInformation("mwd is numeric");
    }
    else
    {
       log.LogInformation("mwd is not numeric");
       dt.Rows[i].Delete();
       i--;
    }
}
dt.AcceptChanges();