当我偶然发现这篇文章时,我刚刚开始使用 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;
}
非常感谢!