2017-12-27 828 views
0

Microsoft.VisualBasic程序集是否與ASP.NET Core2不兼容?System.TypeLoadException Microsoft.VisualBasic ASP.NET Core 2

我有一個C#類庫,提供了一個讀取CSV文件的方法,我選擇使用Microsoft.VisualBasic.FileIO.TextFieldParser來讀取文件。在WPF應用程序中引用該庫方法時效果很好。然而,在ASP.NET的Core2 Web服務,但它編譯沒有錯誤,它會引發在運行時異常:

異常 System.TypeLoadException未能從程序集加載類型「Microsoft.VisualBasic.FileIO.TextFieldParser」 'Microsoft.VisualBasic,Version = 10.0.3.0,Culture = neutral,PublicKeyToken = b03f5f7f11d50a3a'。

我懷疑這是因爲與Core的服務不兼容。我曾嘗試將編譯器標記從NETCOREAPP2更改爲NET461,但Web服務仍然拋出異常。

+0

我認爲CsvHelper現在有Core支持。 – asawyer

回答

0

[這是不完全的答案,但它是在發生上述組件的有效的解決方案。]

我建立這個類來代替由FileIO.TextFieldParser在Microsoft.VisualBasic程序提供的功能和以符合API。以下僅提供我需要的功能,以便根據需要進行擴展。

public class TextFieldParser : StreamReader, IDisposable 
{ 
    int iToken = 1; 
    bool quoted = false; 
    char[] delimiters; 
    string curLine; 

    public TextFieldParser(string path) : base(path) { } 

    public TextFieldParser(Stream stream) : base(stream) { } 

    public string[] ReadFields() 
    { 
     curLine = ReadLine(); 

     return GetFields(); 
    } 

    public void SetDelimiters(string delim) 
    { 
     delimiters = delim.ToCharArray(); 
    } 

    public string[] GetFields() 
    { 
     if (delimiters == null || delimiters.Length == 0) 
      throw new Exception($"{GetType().Name} requires delimiters be defined to identify fields."); 

     if (!hasFieldsEnclosedInQuotes) 
     { 
      return curLine.Split(delimiters); 
     } 
     else 
     { 
      var token = (char)iToken; 
      var sb = new StringBuilder(); 

      // Go through the string and change delimiters to token 
      // ignoring them if within quotes if indicated 
      for (int c = 0; c < curLine.Length; c++) 
      { 
       var qc = curLine[c]; 

       if (hasFieldsEnclosedInQuotes && qc == '"') 
       { 
        quoted = !quoted; 
        continue; 
       } 
       else if (!quoted) 
       { 
        // Replace the delimiters with token 
        for (int d = 0; d < delimiters.Length; d++) 
        { 
         if (qc == delimiters[d]) 
         { 
          qc = token; 
          break; 
         } 
        } 
       } 

       sb.Append(qc); 
      } 

      return sb.ToString().Split(token); 
     } 
    } 

    private bool hasFieldsEnclosedInQuotes = false; 
    public bool HasFieldsEnclosedInQuotes 
    { 
     get { return hasFieldsEnclosedInQuotes; } 
     set { hasFieldsEnclosedInQuotes = value; } 
    } 

    public bool EndOfData 
    { 
     get { return EndOfStream; } 
    }