1

我正在创建一种将枚举转换为友好字符串的方法。友好名称存储在资源文件中并受制于全球化。所以我创建了两个资源文件:Enums.resx 和 Enums.pt-BR.resx,它们的键是枚举的名称,后跟它的值(即 DeliveryStatus_WaitingForPayment)。

这是我用来加载资源并获取枚举的相应友好名称的代码:

public static string EnumToString<T>(object obj)
{
      string key = String.Empty;

      Type type = typeof(T);

      key += type.Name + "_" + obj.ToString();

      Assembly assembly = Assembly.Load("EnumResources");

      string[] resourceNames = assembly.GetManifestResourceNames();

      ResourceManager = null;

      for(int i = 0; i < resourceNames.Length; i++)
      { 
           if(resourceNames[i].Contains("Enums.resources"))
           {
                rm = new ResourceManager(resourceNames[i], Assembly.GetExecutingAssembly());

                Stream resStream = assembly.GetManifestResourceStream(resourceNames[i]);

                ResourceReader reader = new ResourceReader(resStream);

                IDictionaryEnumerator dict = reader.GetEnumerator();

                while (dict.MoveNext())
                {
                     string keyToCompare = dict.Key.ToString();

                     if (keyToCompare == key)
                         return dict.Value.ToString();
                }
           }

           return obj.ToString();
      }

}

此方法几乎可以完美运行,除了它忽略 CurrentUICulture 并始终从默认资源返回值,也就是说,即使我使用 pt-BR 作为我的 CurrentUICulture,它也会从 Enum.resx 而不是 Enum.pt 加载值-BR.resx。

我究竟做错了什么?

4

1 回答 1

1

事实证明,我采用了错误的方法来读取资源文件。不仅我不需要通过流工作,它还阻止我获得基于 CurrentUICulture 的结果。

该解决方案比我第一次尝试的解决方案要容易得多:

public static string EnumToString<T>(object obj)
{
      string key = String.Empty;

      Type type = typeof(T);

      key += type.Name + "_" + obj.ToString();

      Assembly assembly = Assembly.Load("EnumResources");

      string[] resourceNames = assembly.GetManifestResourceNames();

      ResourceManager = null;

      for(int i = 0; i < resourceNames.Length; i++)
      { 
           if(resourceNames[i].Contains("Enums.resources"))
           {
                //The substring is necessary cause the ResourceManager is already expecting the '.resurces'
                rm = new ResourceManager(resourceNames[i].Substring(0, resourceNames[i].Length - 10), assembly);

                return rm.GetString(key);
           }

           return obj.ToString();
      }

}

我希望这可以帮助任何人在未来尝试类似的事情!

于 2010-06-26T19:57:41.627 回答