本文整理汇总了C#中Row.Clone方法的典型用法代码示例。如果您正苦于以下问题:C# Row.Clone方法的具体用法?C# Row.Clone怎么用?C# Row.Clone使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Row
的用法示例。
在下文中一共展示了Row.Clone方法的13个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: MergeRows
protected override Row MergeRows(Row newRow, Row oldRow)
{
Row row;
// if the old row doesn't exist, then the new row is new, and it should be created
if (oldRow["id"] == null) {
row = newRow.Clone();
row["action"] = "Create";
return row;
}
// if the new row doesn't exist, then the old row has been dropped, and it should be marked as dropped and updated
if (newRow["id"] == null) {
row = oldRow.Clone();
row["dropped"] = true;
row["action"] = oldRow["dropped"].Equals(true) ? "None" : "Update";
return row;
}
// if new and old rows are the same, then we have nothing to do.
if (Equal(newRow, oldRow)) {
row = oldRow.Clone();
row["action"] = "None";
return row;
}
// if we end up here, the sql is the same but other properties have been updated, so we should update it.
row = newRow.Clone();
row["action"] = "Update";
row["modified"] = _today;
return row;
}
示例2: MergeRows
protected override Row MergeRows(Row leftRow, Row rightRow)
{
var row = leftRow.Clone();
row["AWord"] = leftRow["Id"] + "," + leftRow["AWord"] + "," +
rightRow["AWord"];
return row;
}
示例3: MergeRows
protected override Row MergeRows(Row leftRow, Row rightRow)
{
Row row = leftRow.Clone();
row["AWord"] = leftRow["AWord"].ToString() + " " +
rightRow["AWord"].ToString();
return row;
}
示例4: MergeRows
protected override Row MergeRows(Row leftRow, Row rightRow) {
var row = leftRow.Clone();
foreach (var field in _fields) {
row[field] = rightRow[field];
}
return row;
}
示例5: MergeRows
protected override Row MergeRows(Row leftRow, Row rightRow)
{
var row = leftRow.Clone();
if (rightRow["use"] != null) {
row["use"] = rightRow["use"];
row["lastused"] = DateTime.Now;
}
return row;
}
示例6: MergeRows
protected override Row MergeRows(Row leftRow, Row rightRow)
{
var row = leftRow.Clone();
if (!leftRow["type"].Equals("Index"))
return row;
if(rightRow["use"] != null)
row["use"] = rightRow["use"];
if(rightRow["lastused"] != null)
row["lastused"] = rightRow["lastused"];
return row;
}
示例7: Should_respect_stringcomparer_specification
public void Should_respect_stringcomparer_specification()
{
Row first = new Row(StringComparer.Ordinal);
first["A"] = 1;
Row second = new Row(StringComparer.Ordinal);
second["a"] = 1;
Row third = second.Clone();
Row fourth = new Row();
fourth.Copy(second);
Assert.False(first.Equals(second));
Assert.False(first.Equals(third));
Assert.False(first.Equals(fourth));
}
示例8: Should_not_take_casing_into_account_in_column_names
public void Should_not_take_casing_into_account_in_column_names()
{
Row first = new Row();
first["A"] = 1;
Row second = new Row();
second["a"] = 1;
Row third = second.Clone();
Row fourth = new Row();
fourth.Copy(third);
Assert.True(first.Equals(second));
Assert.True(first.Equals(third));
Assert.True(first.Equals(fourth));
}
示例9: MergeRows
protected override Row MergeRows(Row leftRow, Row rightRow) {
var row = rightRow.Clone();
if (ThereIsAKeyMatch(leftRow, _firstKey)) {
row["TflAction"] = EntityAction.None;
row["TflDeleted"] = false;
} else {
var isAlreadyDeleted = rightRow["TflDeleted"] != null && (bool)rightRow["TflDeleted"];
if (isAlreadyDeleted) {
row["TflAction"] = EntityAction.None;
row["TflDeleted"] = true;
} else {
row["TflAction"] = EntityAction.Delete;
row["TflDeleted"] = true;
}
}
return row;
}
示例10: MergeRows
protected override Row MergeRows(Row leftRow, Row rightRow)
{
Row row = leftRow.Clone();
row["user_id"] = rightRow["new_id"];
return row;
}
示例11: PrintSubjectOnly
private void PrintSubjectOnly(DocumentBuilder builder, ReportStudent student, Row template, Table table)
{
#region 列印科目
UniqueSet<RowHeader> RowIndexs = new UniqueSet<RowHeader>();
#region 列印 RowHeader
Dictionary<string, string> subjToDomain = new Dictionary<string, string>();
foreach (SemesterData semester in student.SHistory.GetGradeYearSemester())
{
SemesterData sysems = new SemesterData(0, semester.SchoolYear, semester.Semester);
if (!student.SemestersScore.Contains(sysems)) continue;
SemesterScore semsscore = student.SemestersScore[sysems];
foreach (string strSubject in semsscore.Subject)
{
SemesterSubjectScore subject = semsscore.Subject[strSubject];
if (!subjToDomain.ContainsKey(strSubject))
subjToDomain.Add(strSubject, subject.Domain);
RowHeader header = new RowHeader(subjToDomain[strSubject], strSubject);
header.IsDomain = false;
if (!RowIndexs.Contains(header))
RowIndexs.Add(header);
}
}
List<RowHeader> sortedHeaders = RowIndexs.ToList();
sortedHeaders.Sort(delegate(RowHeader x, RowHeader y)
{
Subj xx = new JHSchool.Evaluation.Subject(x.Subject, x.Domain);
Subj yy = new JHSchool.Evaluation.Subject(y.Subject, y.Domain);
return xx.CompareTo(yy);
});
//產生 Row。
List<RowHeader> indexHeaders = new List<RowHeader>();
Row current = template;
int rowIndex = 0;
foreach (RowHeader header in sortedHeaders)
{
RowHeader indexH = header;
indexH.Index = rowIndex++;
indexHeaders.Add(indexH);
Row datarow = table.InsertBefore(template.Clone(true), current) as Row;
string gn = "";
//Additional Classes
string subjCName = header.Subject;
string subjEName = Subj.GetSubjectEnglish(header.Subject);
string subjString = header.Subject + (string.IsNullOrEmpty(subjEName) ? "" : " " + subjEName);
datarow.Cells[0].Write(builder, subjString);
//if (IsFlexible(header.Domain))
//{
// gn = "彈性課程\nAdditional Classes";
// //把空白的領域當成「彈性課程」。
// datarow.Cells[0].Write(builder, gn);
// datarow.Cells[1].Write(builder, subjString);
//}
//else
//{
//}
}
#endregion
#region 填資料
//填資料
foreach (RowHeader header in indexHeaders)
{
SemesterDataCollection semesters = new SemesterDataCollection();
Row row = table.Rows[header.Index + DataRowOffset];
foreach (SemesterData semester in student.SHistory.GetGradeYearSemester())
{
SemesterData sysems = new SemesterData(0, semester.SchoolYear, semester.Semester);
semesters.Add(sysems);
if (!student.SemestersScore.Contains(sysems)) continue;
if (!student.HeaderList.ContainsKey(sysems)) continue;
int columnIndex = student.HeaderList[sysems];
SemesterScore semsscore = student.SemestersScore[sysems];
decimal? score = null;
decimal? weight = null;
//if (header.IsDomain)
//{
// if (semsscore.Domain.Contains(header.Domain))
// {
// score = semsscore.Domain[header.Domain].Value;
// weight = semsscore.Domain[header.Domain].Weight;
// }
//}
//.........这里部分代码省略.........
示例12: PrintDomainOnly
private void PrintDomainOnly(DocumentBuilder builder, ReportStudent student, Row template, Table table)
{
#region 列印領域
UniqueSet<RowHeader> RowIndexs = new UniqueSet<RowHeader>();
#region 列印 RowHeader
foreach (SemesterData semester in student.SHistory.GetGradeYearSemester())
{
SemesterData sysems = new SemesterData(0, semester.SchoolYear, semester.Semester);
//如果不包含該學期成績資料,就跳過。
if (!student.SemestersScore.Contains(sysems)) continue;
SemesterScore semsscore = student.SemestersScore[sysems];
//準備彈性課程的科目(要詳列出來)。
foreach (string strSubject in semsscore.Subject)
{
SemesterSubjectScore subject = semsscore.Subject[strSubject];
if (DetailDomain.Contains(subject.Domain))
{
RowHeader header = new RowHeader(subject.Domain, strSubject);
header.IsDomain = false;
if (!RowIndexs.Contains(header))
RowIndexs.Add(header);
}
}
//準備領域資料。
foreach (string strDomain in semsscore.Domain)
{
if (!Subj.Domains.Contains(strDomain)) continue;
SemesterDomainScore domain = semsscore.Domain[strDomain];
if (!DetailDomain.Contains(strDomain))
{
RowHeader header = new RowHeader(strDomain, string.Empty);
header.IsDomain = true;
if (!RowIndexs.Contains(header))
RowIndexs.Add(header);
}
}
}
List<RowHeader> sortedHeaders = SortHeader(RowIndexs.ToList());
//產生 Row。
List<RowHeader> indexHeaders = new List<RowHeader>();
Row current = template;
int rowIndex = 0;
foreach (RowHeader header in sortedHeaders)
{
RowHeader indexH = header;
indexH.Index = rowIndex++;
indexHeaders.Add(indexH);
bool hasGroup = !string.IsNullOrEmpty(Subj.GetDomainGroup(header.Domain));
string groupName = Subj.GetDomainGroup(header.Domain);
Row datarow = table.InsertBefore(template.Clone(true), current) as Row;
if (header.IsDomain)
{
string domainCName = header.Domain;
string domainEName = Subj.GetDomainEnglish(header.Domain);
string domainString = domainCName + (string.IsNullOrEmpty(domainEName) ? "" : domainEName);
if (hasGroup)
{
string gn = groupName;
if (groupName == "語文")
gn = "語文\nLanguage";
datarow.Cells[0].Write(builder, gn);
datarow.Cells[1].Write(builder, domainString);
}
else
datarow.Cells[0].Write(builder, domainString);
}
else
{
string gn = "";
//Additional Classes
if (IsFlexible(header.Domain))
gn = "彈性課程\nAdditional Classes";
else
gn = header.Domain;
string subjCName = header.Subject;
string subjEName = Subj.GetSubjectEnglish(header.Subject);
string subjString = header.Subject + (string.IsNullOrEmpty(subjEName) ? "" : "\n" + subjEName);
//把空白的領域當成「彈性課程」。
string domain = gn;
datarow.Cells[0].Write(builder, domain);
//.........这里部分代码省略.........
示例13: AddInnerRow
private static void AddInnerRow(ref Row innerRow, ref Row outerRow, ref List<Row> innerRows) {
var r = innerRow.Clone();
foreach (var column in outerRow.Columns.Where(column => !r.ContainsKey(column))) {
r[column] = outerRow[column];
}
innerRows.Add(r);
innerRow = new Row();
}