Skip to content

Instantly share code, notes, and snippets.

@MarkPflug
Created November 7, 2022 16:53
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save MarkPflug/24937eff934592002d810f4d906c8aaa to your computer and use it in GitHub Desktop.
Save MarkPflug/24937eff934592002d810f4d906c8aaa to your computer and use it in GitHub Desktop.
Excel to HTML
using Sylvan.Data.Excel;
using var r = ExcelDataReader.Create("Data.xlsx");
r.WriteHtmlTable(Console.Out);
static class DataExtensions
{
public static long WriteHtmlTable(this System.Data.Common.DbDataReader data, TextWriter writer)
{
long count = 0;
writer.WriteLine("<table>");
writer.WriteLine("<tr>");
for (int i = 0; i < data.FieldCount; i++)
{
writer.Write("<th>");
var name = data.GetName(i);
writer.Write(System.Net.WebUtility.HtmlEncode(name));
writer.WriteLine("</th>");
}
writer.WriteLine("</tr>");
while (data.Read())
{
count++;
writer.WriteLine("<tr>");
for (int i = 0; i < data.FieldCount; i++)
{
writer.Write("<td>");
var value = data.GetValue(i);
var str = value?.ToString() ?? string.Empty;
writer.Write(System.Net.WebUtility.HtmlEncode(str));
writer.WriteLine("</td>");
}
writer.WriteLine("</tr>");
}
writer.WriteLine("</table>");
return count;
}
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment