2

当我偶然发现这篇文章时,我刚刚开始使用 SSIS 和通过 C# 处理 Excel 文件:

关联

本文介绍了如何通过 SSIS 将 Excel 数据加载到 SQL Server 数据库中。

但是,我需要从特定行(例如第 9 行)开始提取所有行,而不是一些 select 语句。现在我的问题是,我需要更改/删除哪些代码才能让我设置起始行而不需要使用任何标题信息?

public SourceFileDetails ScanRows(DataSet excelDataSet, string ExtractionStatement, string FindColumn)
{
        if (excelDataSet.Tables.Count < 1)
            return (SourceFileDetails)null;

        string ExtractFields = this.ReplaceString(this.ReplaceString(ExtractionStatement, "SELECT", ""), "From [Data$]", "");
        List<string> FindStrings = ExtractFields.Split(',').Select(s => s.Trim().Replace("[", "").Replace("]", "").Replace("#", ".").Replace("(", "").Replace(")", "")).ToList();

        foreach (DataTable dt in excelDataSet.Tables)
        {
            List<ItemValueHolder> FoundAddress = new List<ItemValueHolder>();
            int iDuplicates = 0;

            foreach (DataRow dr in dt.Rows)
            {
                int iItemColumnIndex = 0;
                foreach (var fieldValue in dr.ItemArray)
                {
                    object cellData = fieldValue;
                    string sCellData = cellData.ToString().Replace("#", ".").Replace("[", "").Replace("]", "").Replace("(", "").Replace(")", "");

                    if (cellData != null)

                        if (FindStrings.Exists(delegate(string k) { return k.ToLower() == sCellData.ToString().ToLower(); }))
                        {
                            if (!FoundAddress.Exists(delegate(ItemValueHolder t) { return t.Item.ToLower() == sCellData.ToLower(); }))
                                FoundAddress.Add(new ItemValueHolder(sCellData, dt.Rows.IndexOf(dr), iItemColumnIndex));
                            else
                                iDuplicates++;
                        }
                    iItemColumnIndex++;
                }
                int iTotalFields = FindStrings.Count - iDuplicates;

                if (100 * FoundAddress.Count / (float)iTotalFields >= 90.00)
                {
                    var query = FoundAddress.GroupBy(
                item => item.ItemValue,
                (itemvalue, items) => new
                {
                    Key = (int)itemvalue,
                    Count = items.Count(),
                });


                    int dataStartAddress = (from p in query
                                            where p.Count == (query.Max(it => it.Count))
                                            select p.Key).Max();
                    dataStartAddress += 1;
                    string SheetName = "[" + dt.TableName + "$A" + dataStartAddress.ToString() + ":IV]";
                    string _selectCommand = this.ReplaceString(ExtractionStatement, "[Data$]", SheetName);
                    string reportDate = "";
                    if (!string.IsNullOrEmpty(FindColumn))
                        try
                        {

                            int ColIndex = (from p in FoundAddress
                                            where p.Item.ToLower() == FindColumn.ToLower()
                                            select p.ColumnIndex).First();
                            DataRow drRowReport = dt.Rows[dataStartAddress];
                            reportDate = drRowReport[ColIndex].ToString();

                        }
                        catch (Exception e)
                        {
                            //log 
                        }
                    string NewFields = GetNewFieldsAtSource(FindStrings, dr);
                    return new SourceFileDetails("", "", "", _selectCommand, reportDate, NewFields);
                }
            }
        }
        return (SourceFileDetails)null;
    } 

非常感谢!

4

0 回答 0