Skip to content

Commit 35863f2

Browse files
ES-264021-Generate-Documents-for-each-record
1 parent 102d5f1 commit 35863f2

File tree

5 files changed

+118
-0
lines changed

5 files changed

+118
-0
lines changed
Lines changed: 25 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,25 @@
1+
2+
Microsoft Visual Studio Solution File, Format Version 12.00
3+
# Visual Studio Version 16
4+
VisualStudioVersion = 16.0.31911.196
5+
MinimumVisualStudioVersion = 10.0.40219.1
6+
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Generate-Documents-for-each-record", "Generate-Documents-for-each-record\Generate-Documents-for-each-record.csproj", "{C17B90BC-F559-456B-B189-90B53FF6CDD4}"
7+
EndProject
8+
Global
9+
GlobalSection(SolutionConfigurationPlatforms) = preSolution
10+
Debug|Any CPU = Debug|Any CPU
11+
Release|Any CPU = Release|Any CPU
12+
EndGlobalSection
13+
GlobalSection(ProjectConfigurationPlatforms) = postSolution
14+
{C17B90BC-F559-456B-B189-90B53FF6CDD4}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
15+
{C17B90BC-F559-456B-B189-90B53FF6CDD4}.Debug|Any CPU.Build.0 = Debug|Any CPU
16+
{C17B90BC-F559-456B-B189-90B53FF6CDD4}.Release|Any CPU.ActiveCfg = Release|Any CPU
17+
{C17B90BC-F559-456B-B189-90B53FF6CDD4}.Release|Any CPU.Build.0 = Release|Any CPU
18+
EndGlobalSection
19+
GlobalSection(SolutionProperties) = preSolution
20+
HideSolutionNode = FALSE
21+
EndGlobalSection
22+
GlobalSection(ExtensibilityGlobals) = postSolution
23+
SolutionGuid = {EF357FC6-E9E5-4E3C-B932-43F727BE1DE4}
24+
EndGlobalSection
25+
EndGlobal
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,22 @@
1+
<Project Sdk="Microsoft.NET.Sdk">
2+
3+
<PropertyGroup>
4+
<OutputType>Exe</OutputType>
5+
<TargetFramework>net8.0</TargetFramework>
6+
<RootNamespace>Generate_Documents_for_each_record</RootNamespace>
7+
</PropertyGroup>
8+
9+
<ItemGroup>
10+
<PackageReference Include="Syncfusion.DocIO.Net.Core" Version="*" />
11+
</ItemGroup>
12+
13+
<ItemGroup>
14+
<None Update="Data\Template.docx">
15+
<CopyToOutputDirectory>Always</CopyToOutputDirectory>
16+
</None>
17+
<None Update="Output\.gitkeep">
18+
<CopyToOutputDirectory>Always</CopyToOutputDirectory>
19+
</None>
20+
</ItemGroup>
21+
22+
</Project>
Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+

Lines changed: 70 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,70 @@
1+
using Syncfusion.DocIO;
2+
using Syncfusion.DocIO.DLS;
3+
using System.Data;
4+
using System.IO;
5+
6+
namespace Generate_Documents_for_each_record
7+
{
8+
class Program
9+
{
10+
static void Main(string[] args)
11+
{
12+
//Open the file as Stream.
13+
using (FileStream fileStream = new FileStream(Path.GetFullPath(@"Data/Template.docx"), FileMode.Open))
14+
{
15+
//Load file stream into Word document.
16+
using (WordDocument document = new WordDocument(fileStream, FormatType.Docx))
17+
{
18+
//Get the data for mail merge.
19+
DataTable table = GetDataTable();
20+
//Iterate to the each row and generate mail merged document for each rows.
21+
for (int i = 0; i < table.Rows.Count; i++)
22+
{
23+
//Executes mail merge using the data row.
24+
document.MailMerge.Execute(table.Rows[i]);
25+
26+
//Create a file stream.
27+
using (FileStream outputFileStream = new FileStream(Path.GetFullPath(@"Output/" + "Record_" + (i + 1) + ".docx"), FileMode.Create, FileAccess.ReadWrite))
28+
{
29+
//Save the Word document to the file stream.
30+
document.Save(outputFileStream, FormatType.Docx);
31+
}
32+
}
33+
}
34+
}
35+
}
36+
/// <summary>
37+
/// Get the data for mail merge.
38+
/// </summary>
39+
/// <returns></returns>
40+
static DataTable GetDataTable()
41+
{
42+
DataTable table = new DataTable();
43+
44+
//Defining columns
45+
table.Columns.Add("Name");
46+
table.Columns.Add("Street");
47+
table.Columns.Add("City");
48+
table.Columns.Add("ProjectNo");
49+
50+
//Set values
51+
DataRow row;
52+
row = table.NewRow();
53+
row["Name"] = "Andreas Waning";
54+
row["Street"] = "Middelwegg 2";
55+
row["City"] = "Vreden";
56+
row["ProjectNo"] = "4711";
57+
table.Rows.Add(row);
58+
59+
row = table.NewRow();
60+
row["Name"] = "Mike Korf";
61+
row["Street"] = "teststreet";
62+
row["City"] = "TestCity";
63+
row["ProjectNo"] = "4711";
64+
table.Rows.Add(row);
65+
66+
return table;
67+
}
68+
}
69+
}
70+

0 commit comments

Comments
 (0)