Skip to content

Commit d6bee7f

Browse files
Mail-merge-date-in-German-culture
1 parent 983f660 commit d6bee7f

File tree

5 files changed

+99
-0
lines changed

5 files changed

+99
-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}") = "Mail-merge-date-in-German-culture", "Mail-merge-date-in-German-culture\Mail-merge-date-in-German-culture.csproj", "{D3AF529E-DB54-4294-A876-DD42E1E472D0}"
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+
{D3AF529E-DB54-4294-A876-DD42E1E472D0}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
15+
{D3AF529E-DB54-4294-A876-DD42E1E472D0}.Debug|Any CPU.Build.0 = Debug|Any CPU
16+
{D3AF529E-DB54-4294-A876-DD42E1E472D0}.Release|Any CPU.ActiveCfg = Release|Any CPU
17+
{D3AF529E-DB54-4294-A876-DD42E1E472D0}.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 = {58137FF9-5AE1-4514-9929-3A8A7DA1DFEB}
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>Mail_merge_date_in_German_culture</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: 51 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,51 @@
1+
using Syncfusion.DocIO;
2+
using Syncfusion.DocIO.DLS;
3+
using System;
4+
using System.IO;
5+
6+
namespace Mail_merge_date_in_German_culture
7+
{
8+
class Program
9+
{
10+
static void Main(string[] args)
11+
{
12+
using (FileStream fileStream = new FileStream(Path.GetFullPath(@"Data/Template.docx"), FileMode.Open, FileAccess.ReadWrite))
13+
{
14+
//Opens the template document.
15+
using (WordDocument document = new WordDocument(fileStream, FormatType.Docx))
16+
{
17+
//Execute mail merge
18+
string[] fieldnames = { "Name", "Date" };
19+
string[] fieldvalues = { "Andrew", DateTime.Now.ToString() };
20+
21+
//Hook the even to do the date format changes during mail merge
22+
document.MailMerge.MergeField += ChangeDateLanguauge;
23+
document.MailMerge.Execute(fieldnames, fieldvalues);
24+
//Creates file stream.
25+
using (FileStream outputStream = new FileStream(Path.GetFullPath(@"Output/Result.docx"), FileMode.Create, FileAccess.ReadWrite))
26+
{
27+
//Saves the Word document to file stream.
28+
document.Save(outputStream, FormatType.Docx);
29+
}
30+
}
31+
}
32+
}
33+
34+
static void ChangeDateLanguauge(object sender, MergeFieldEventArgs args)
35+
{
36+
//Check whether date is merge for this merge field
37+
if (args.FieldName == "Date")
38+
{
39+
//Get the date value
40+
string dateValue = args.FieldValue.ToString();
41+
//Parse the date value
42+
DateTime date = DateTime.Parse(dateValue);
43+
//Convert the date value to German culture in the same date format
44+
string formattedDate = date.ToString(args.CurrentMergeField.DateFormat, new System.Globalization.CultureInfo("de-DE"));
45+
//Set the date value to the current merge field
46+
args.Text = formattedDate;
47+
48+
}
49+
}
50+
}
51+
}

0 commit comments

Comments
 (0)