我使用以下代码将所选行从DatagGridview
导出到Word文档。代码正在运行,但有一个问题。它首先导出最后一行,我无法找到使其按顺序导出的方法。例如,如果我选择行[0,1,2,3],它将导出行[3]而不是[2]和[1]。任何想法问题是什么?
public void WordDoc(string getfilename)
{
object FileName = getfilename;
//Create word Application Object
Word.Application word = new Word.Application();
//Create word document Object
Word.Document doc = null;
//Create word Missing Object
object missing = System.Type.Missing;
object readOnly = false;
object isVisible = false;
// make visible Word application
word.Visible = true;
try
{
doc = word.Documents.Open(ref FileName, ref missing, ref missing,
ref missing, ref missing, ref missing, ref missing, ref missing,
ref missing, ref missing, ref missing, ref missing, ref missing,
ref missing, ref missing, ref missing);
doc.Activate();
foreach (DataGridViewRow rows in dataGridView1.SelectedRows)
{
string item1 = rows.Cells[0].Value.ToString();
string item2 = rows.Cells[2].Value.ToString();
string item3 = rows.Cells[3].Value.ToString();
string item4 = rows.Cells[4].Value.ToString();
string item5 = rows.Cells[5].Value.ToString();
string item6 = rows.Cells[6].Value.ToString();
string item7 = rows.Cells[7].Value.ToString();
string item8 = rows.Cells[8].Value.ToString();
string item9 = rows.Cells[9].Value.ToString();
string item10 = rows.Cells[10].Value.ToString();
string item11 = rows.Cells[11].Value.ToString();
string item12 = rows.Cells[12].Value.ToString();
this.FindAndReplace(word, "!0!", item1);
this.FindAndReplace(word, "!1!", item2);
this.FindAndReplace(word, "!2!", item3);
this.FindAndReplace(word, "!3!", item4);
this.FindAndReplace(word, "!4!", item5);
this.FindAndReplace(word, "!5!", item6);
this.FindAndReplace(word, "!6!", item7);
this.FindAndReplace(word, "!7!", item8);
this.FindAndReplace(word, "!8!", item9);
this.FindAndReplace(word, "!9!", item10);
this.FindAndReplace(word, "!10!", item11);
this.FindAndReplace(word, "!11!", item12);
}
}
catch (Exception ex)
{
MessageBox.Show("Error : " + ex.Message);
}
}
private void FindAndReplace(Word.Application word, object findText, object replaceText)
{
word.Selection.Find.ClearFormatting();
object matchCase = true;
object matchWholeWord = true;
object matchWildCards = false;
object matchSoundsLike = false;
object matchAllWordForms = false;
object forward = true;
object format = true;
object matchKashida = false;
object matchDiacritics = false;
object matchAlefHamza = false;
object matchControl = false;
object read_only = false;
object visible = true;
object replace = 1;
object wrap = 2;
word.Selection.Find.Execute(ref findText, ref matchCase,
ref matchWholeWord, ref matchWildCards, ref matchSoundsLike,
ref matchAllWordForms, ref forward, ref wrap, ref format,
ref replaceText, ref replace, ref matchKashida,
ref matchDiacritics,
ref matchAlefHamza, ref matchControl);
}
答案 0 :(得分:0)
我认为这个Linq应该有用(你需要{&#34}位于" .cs"文件的顶部。):
using System.Linq;
[编辑] OP要求的更多信息:
这是使用Linq按照每行索引的顺序对返回的行进行排序。
See this documentation for an introduction to Linq
但简单地说,它的工作方式是这样的:
首先,要意识到DataGridView.SelectedRows按照用户选择的顺序返回行。
为了按照正确的顺序排列它们,我们需要按每行var orderedRows = from DataGridViewRow row in dataGridView1.SelectedRows
orderby row.Index
select row;
foreach (DataGridViewRow row in orderedRows)
...
属性对它们进行排序。
上面的Linq说:
"获取dataGridView1.SelectedRows中的所有行,并按每行的Index属性对它们进行排序,然后按顺序返回所有行"。
但这太复杂了,无法完全进入这里;你必须阅读我发布的Linq简介!