aboutsummaryrefslogtreecommitdiffstats
path: root/Software/Visual_Studio/Tango.CSV
diff options
context:
space:
mode:
authorRoy Ben Shabat <Roy.mail.net@gmail.com>2020-08-26 15:28:39 +0300
committerRoy Ben Shabat <Roy.mail.net@gmail.com>2020-08-26 15:28:39 +0300
commite29b5a014cdd594279b4a5124eca9d1cfa67d77d (patch)
tree4b16cf3d82f3d515962533def80d89c509e90c0f /Software/Visual_Studio/Tango.CSV
parent09fb88e4ac3bfa7cb7b920b822a3470689f68fd3 (diff)
downloadTango-e29b5a014cdd594279b4a5124eca9d1cfa67d77d.tar.gz
Tango-e29b5a014cdd594279b4a5124eca9d1cfa67d77d.zip
Implemented dynamic csv file.
Implemented insights export to csv.
Diffstat (limited to 'Software/Visual_Studio/Tango.CSV')
-rw-r--r--Software/Visual_Studio/Tango.CSV/DynamicCsvFile.cs100
-rw-r--r--Software/Visual_Studio/Tango.CSV/DynamicCsvFileColumn.cs13
-rw-r--r--Software/Visual_Studio/Tango.CSV/Tango.CSV.csproj2
3 files changed, 115 insertions, 0 deletions
diff --git a/Software/Visual_Studio/Tango.CSV/DynamicCsvFile.cs b/Software/Visual_Studio/Tango.CSV/DynamicCsvFile.cs
new file mode 100644
index 000000000..0c4d79949
--- /dev/null
+++ b/Software/Visual_Studio/Tango.CSV/DynamicCsvFile.cs
@@ -0,0 +1,100 @@
+using System;
+using System.Collections;
+using System.Collections.Generic;
+using System.IO;
+using System.Linq;
+using System.Text;
+using System.Threading.Tasks;
+
+namespace Tango.CSV
+{
+ public class DynamicCsvFile : IDisposable
+ {
+ private bool _isDisposed;
+ private Stream _stream;
+ private StreamWriter _writer;
+ private bool _disposeStream;
+ private bool _columnsWritten;
+
+ public List<DynamicCsvFileColumn> Columns { get; set; }
+
+ public DynamicCsvFile()
+ {
+ Columns = new List<DynamicCsvFileColumn>();
+ }
+
+ public DynamicCsvFile(Stream stream) : this()
+ {
+ _stream = stream;
+ _writer = new StreamWriter(_stream);
+ }
+
+ public DynamicCsvFile(String file) : this(new FileStream(file, FileMode.Create))
+ {
+ _disposeStream = true;
+ }
+
+ private void WriteColumns()
+ {
+ if (!_columnsWritten)
+ {
+ _columnsWritten = true;
+ _writer.WriteLine(String.Join(",", Columns.Select(x => x.Name)));
+ }
+ }
+
+ public void Append(params Object[] values)
+ {
+ Append((IEnumerable)values);
+ }
+
+ public void Append<T>(IEnumerable<T> values, Func<T, Object> modifier = null)
+ {
+ if (modifier != null)
+ {
+ Append((IEnumerable)values, (x) => { return modifier((T)x); });
+ }
+ else
+ {
+ Append((IEnumerable)values, null);
+ }
+ }
+
+ public void Append(IEnumerable values, Func<Object, Object> modifier = null)
+ {
+ if (!_columnsWritten)
+ {
+ WriteColumns();
+ }
+
+ List<String> valuesStr = new List<string>();
+
+ foreach (var value in values)
+ {
+ Object finalValue = value;
+
+ if (modifier != null)
+ {
+ finalValue = modifier(finalValue);
+ }
+
+ valuesStr.Add(finalValue != null ? finalValue.ToString() : String.Empty);
+ }
+
+ _writer.WriteLine(String.Join(",", valuesStr));
+ }
+
+ public void Dispose()
+ {
+ if (!_isDisposed)
+ {
+ _isDisposed = true;
+
+ if (_disposeStream)
+ {
+ _stream?.Dispose();
+ }
+ }
+ }
+ }
+}
diff --git a/Software/Visual_Studio/Tango.CSV/DynamicCsvFileColumn.cs b/Software/Visual_Studio/Tango.CSV/DynamicCsvFileColumn.cs
new file mode 100644
index 000000000..c8fd850e7
--- /dev/null
+++ b/Software/Visual_Studio/Tango.CSV/DynamicCsvFileColumn.cs
@@ -0,0 +1,13 @@
+using System;
+using System.Collections.Generic;
+using System.Linq;
+using System.Text;
+using System.Threading.Tasks;
+
+namespace Tango.CSV
+{
+ public class DynamicCsvFileColumn
+ {
+ public String Name { get; set; }
+ }
+}
diff --git a/Software/Visual_Studio/Tango.CSV/Tango.CSV.csproj b/Software/Visual_Studio/Tango.CSV/Tango.CSV.csproj
index c3e455ff1..b6743bede 100644
--- a/Software/Visual_Studio/Tango.CSV/Tango.CSV.csproj
+++ b/Software/Visual_Studio/Tango.CSV/Tango.CSV.csproj
@@ -87,6 +87,8 @@
<Compile Include="CsvIgnoreAttribute.cs" />
<Compile Include="CsvOrderAttribute.cs" />
<Compile Include="CsvSource.cs" />
+ <Compile Include="DynamicCsvFile.cs" />
+ <Compile Include="DynamicCsvFileColumn.cs" />
<Compile Include="Properties\AssemblyInfo.cs" />
</ItemGroup>
<Import Project="$(MSBuildToolsPath)\Microsoft.CSharp.targets" />