繁体   English   中英

从字典c#将数据输出到CSV特定列

[英]Output data to CSV specific columns from Dictionary c#

我正在尝试将字典中的值输出到CSV,并且能够做到这一点。 但是面对特定列的问题,这需要输出到csv。 我需要字典中的特定数据值才能输出到csv中的特定列。

Dictionary<string, List<string>> file = new Dictionary<string, List<string>>();

for (var i = 0; i < stringList.Count(); i++)
{
    string line = stringList[i];
    string path = line.Replace("\r\n", "");
    path = path.Replace(" ", "");
    path = path.TrimEnd(':');

    if (File.Exists(path))
    {
        file[path] = file.ContainsKey(path) ? file[path] : new List<string>();
        for (var j = i + 1; j < stringList.Count(); j++)
        {
            string line2 = stringList[j];
            string path2 = line2.Replace("\r\n", "");
            path2 = path2.Replace(" ", "");
            path2 = path2.TrimEnd(':');

            if (File.Exists(path2))
            {
                i = j - 1;
                break;
            }
            else
            {
                if (path2.Contains("Verified") | path2.Contains("Algorithm"))
                {
                    var strings = path2.Split(':');
                    var listValue = strings[1].Trim();
                    file[path].Add(listValue);
                }
            }
        }
    }
}                

using (var writer = new StreamWriter(outputdir + "\\output_" + 
        DateTime.Now.ToString("yyyy_MM_dd_HHmmss") + ".csv"))
{
    writer.WriteLine("FilePath,Signature,HashValueSHA1, HashValueSHA2, HashValueMD5, Other");
    foreach (var keyvaluepair in file)
    {
        if (!keyvaluepair.Value.Contains("Unsigned"))
        {
            var values = String.Join(",", keyvaluepair.Value.Distinct().Select(x => x.ToString()).ToArray());
            writer.WriteLine("{0},{1}", keyvaluepair.Key, values);
        }
    }
}

当前输出如下所示:

当前的CSV输出以及上面的代码

我需要的示例输出如下:

CSV输出

字典键(字符串)将保存文件路径,而值(列表)将保存如下内容:

签名的sha1RSA md5RSA md5RSA

签名的sha1RSA sha1RSA sha256RSA sha256RSA

请建议如何获得所需的输出。

输入的答案更长,但我看到了问题。

在这条线上

var values = String.Join(",", keyvaluepair.Value.Distinct().Select(x => x.ToString()).ToArray());

拿出Distinct 看起来每个字符串中的项目数量正确,但是如果列表包含多个空白条目, Distinct将消除重复项。 如果列表包含两个或三个空白条目,则需要全部。 如果删除重复的空白,则您的列将不会对齐。

同样,当您使用Distinct ,不能保证物品会以任何特定顺序返回。 在这种情况下,顺序非常重要,因此值最终会出现在右列中。

因此,在上面的示例中,即使第一行的第三列中有一个空格,第四列中的值也将在第三列中结束,并且该空格将结束。


这可能会解决当前的问题。 当您期望一定数量的值(它们需要与列匹配)时,建议不要使用List<string> ,因为List<string>可以包含任意数量的值。

而是尝试这样的事情:

public class WhateverThisIs
{
    public string Signature { get; set; }
    public string HashValueSha1 { get; set; }
    public string HashValueSha2 { get; set; }
    public string HashValueMd5 { get; set; }
    public string Other { get; set; }
}

然后,使用Dictionary<string, WhateverThisIs>作为起点。

然后,输出线的部分将看起来像这样:

var value = keyvaluepair.Value;
var values = String.Join(",", value.Signature, value.HashValueSha1, value.HashValueSha2,
    value.HashValueMd5, value.Other);

(是的,这说明了空值。)

如果要用“ N / A”替换空值或空值,则需要一个单独的函数,例如

string ReplaceNullWithNa(string value)
{
    return string.IsNullOrEmpty(value) ? "N/A" : value;
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM