删除'-'之后的字符串,并分组其余的字符串和枢轴列

时间:2019-02-21 07:36:17

标签: c# .net pivot oledbdataadapter

这是我在Excel中的实际数据,可以在C#Windows应用程序的DataGridView中成功读取。

Test       | Energy |
---------------------
C018-3L-1  | 113    |
C018-3L-2  | 79     |
C018-3L-3  | 89     |
C018-3L-4  | 90     |
C018-3L-5  | 95     |
C021-3T-1  | 115    |
C021-3T-2  | 100    |

但是现在我想要从Excel文件中以格式下面的格式在DataGridView中使用此数据:

Test    |Energy-1|Energy-2|Energy-3 |
------------------------------------
C018-3L |113     |79      |89       |
C018-3L |90      |95      |NULL     |
C021-3T |115     |100     |NULL     |

这是我的代码:

    private void TensileEnergyData_Load(object sender, EventArgs e)
    {
        try
        {
            string sourcefilepath = ConfigurationManager.AppSettings["FilePath"].ToString();

            string[] files = Directory.GetFiles(sourcefilepath, "*.xlsx");
            foreach (string s in files)
            {
                string excelConnectionString = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" + s + ";Extended Properties='Excel 12.0;HDR=YES';";

                // Create Connection to Excel Workbook
                using (OleDbConnection connection = new OleDbConnection(excelConnectionString))
                {
                    connection.Open();
                    da = new OleDbDataAdapter("Select Test, Energy FROM [Sheet1$]", connection);
                    da.Fill(dtExcelData);
                    connection.Close();
                }
            }
        }
        catch (Exception ex)
        {
            objDAL.SendExcepToDB(ex, "TensileEnergyData_Load");
            MessageBox.Show("Fail to read data...!!");
        }
        dataGridView1.Visible = true;
        dataGridView1.DataSource = dtExcelData;
    }

如何使用分组依据来实现?

1 个答案:

答案 0 :(得分:1)

我将根据您的related question的要求提供基于SQL Server的答案。在这里,您根本没有使用[sql-server]标记问题。希望这对您有所帮助...

这是一个很好的理由,为什么永远不要在一个列中放置多个内容。将此存储在单独的列中,这将更加容易。

更进一步,这闻起来有点……这些问题应该在您的表示层中解决。

尽管如此,还是可以做到的:

DECLARE @tbl TABLE(Test VARCHAR(100),Energy INT);
INSERT INTO @tbl VALUES
 ('C018-3L-1',113)
,('C018-3L-2',79)
,('C018-3L-3',89)
,('C018-3L-4',90)
,('C018-3L-5',95)
,('C021-3T-1',115)
,('C021-3T-2',100);

SELECT p.*
FROM
(
    SELECT B.Code
          ,(B.Number-1)/3 AS Line
          ,CONCAT('Energy-',CASE B.Number % 3 WHEN 0 THEN 3 ELSE B.Number % 3 END) AS ColumnName
          ,Energy
    FROM @tbl t
    CROSS APPLY(SELECT LEN(t.Test) - CHARINDEX('-',REVERSE(t.Test))) A(PosLastHyphen)
    CROSS APPLY(SELECT LEFT(t.Test,PosLasthyphen) AS Code
                      ,CAST(SUBSTRING(t.Test,PosLastHyphen+2,10) AS INT) AS Number) B
) tbl
PIVOT
(
    MAX(Energy) FOR ColumnName IN([Energy-1],[Energy-2],[Energy-3])
) p
ORDER BY Code,Line;

结果

+---------+------+----------+----------+----------+
| Code    | Line | Energy-1 | Energy-2 | Energy-3 |
+---------+------+----------+----------+----------+
| C018-3L | 0    | 113      | 79       | 89       |
+---------+------+----------+----------+----------+
| C018-3L | 1    | 90       | 95       | NULL     |
+---------+------+----------+----------+----------+
| C021-3T | 0    | 115      | 100      | NULL     |
+---------+------+----------+----------+----------+

一些解释

我使用CROSS APPLY来计算您的代码与运行编号之间的距离。然后,我使用整数除法来计算组,并使用模运算符% 将其分布在三列中。