博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
解析大型.NET ERP系统 多国语言实现
阅读量:7089 次
发布时间:2019-06-28

本文共 5979 字,大约阅读时间需要 19 分钟。

实现多国语言有许多种实现方案,无外乎是一种字符串替换技术,将界面控件的文本标签替换成相应语言的文字。.NET Windows Forms实现多国语言的方法有以下几种:

1 .NET的方案,使用资源文件

分别做三个语言的资源文件,比如String.resx,String.zh-cn.resx,String.zh-tw.resx,编译程序集,运行时用下面的代码设置程序的语言区域。

string languageName="zh-cn";Thread.CurrentThread.CurrentUICulture = CultureInfo.GetCultureInfo(languageName)  Thread.CurrentThread.CurrentCulture = CultureInfo.GetCultureInfo(languageName)

2 使用Xml格式的资源文件

创建Xml格式的资源文件,保存一种或多种语言的字符串,运行时根据用户所选的语言进行界面标签字符串替换。

例子Xml字符串文件如下:

3 数据库方案

将语言资源字符串存放在数据库中,运行时读取并替换,这是我推荐的方案。

设计语言翻译数据库表,用于存放语言翻译内容,表结构如下:

CREATE TABLE [dbo].[LanguageTranslation]([LanguageCode] [nvarchar] (1) COLLATE SQL_Latin1_General_CP1_CI_AS NOT NULL,[KeyText] [nvarchar] (200) COLLATE SQL_Latin1_General_CP1_CI_AS NOT NULL CONSTRAINT,[DisplayText] [nvarchar] (200) COLLATE SQL_Latin1_General_CP1_CI_AS NULL,[CreatedDate] [datetime] NULL,[CreatedBy] [nvarchar] (10) COLLATE SQL_Latin1_General_CP1_CI_AS NULL,[RevisedDate] [datetime] NULL,[RevisedBy] [nvarchar] (10) COLLATE SQL_Latin1_General_CP1_CI_AS NULL) ON [PRIMARY]GOALTER TABLE [dbo].[LanguageTranslation] ADD CONSTRAINT [PK_LanguageTranslation] PRIMARY KEY CLUSTERED  ([LanguageCode], [KeyText]) ON [PRIMARY]GOEXEC sp_addextendedproperty N'MS_Description', N'翻译', 'SCHEMA', N'dbo', 'TABLE', N'LanguageTranslation', NULL, NULLGOEXEC sp_addextendedproperty N'MS_Description', N'语言编码0  英语1  繁体中文2  简体中文', 'SCHEMA', N'dbo', 'TABLE', N'LanguageTranslation', 'COLUMN', N'LanguageCode'GOEXEC sp_addextendedproperty N'MS_Description', N'索引词', 'SCHEMA', N'dbo', 'TABLE', N'LanguageTranslation', 'COLUMN', N'KeyText'GOEXEC sp_addextendedproperty N'MS_Description', N'显示词', 'SCHEMA', N'dbo', 'TABLE', N'LanguageTranslation', 'COLUMN', N'DisplayText'GOEXEC sp_addextendedproperty N'MS_Description', N'创建日期', 'SCHEMA', N'dbo', 'TABLE', N'LanguageTranslation', 'COLUMN', N'CreatedDate'GOEXEC sp_addextendedproperty N'MS_Description', N'建立人', 'SCHEMA', N'dbo', 'TABLE', N'LanguageTranslation', 'COLUMN', N'CreatedBy'GOEXEC sp_addextendedproperty N'MS_Description', N'修改日期', 'SCHEMA', N'dbo', 'TABLE', N'LanguageTranslation', 'COLUMN', N'RevisedDate'GOEXEC sp_addextendedproperty N'MS_Description', N'修改人', 'SCHEMA', N'dbo', 'TABLE', N'LanguageTranslation', 'COLUMN', N'RevisedBy'GO

我以Language Code和相应的字符串为主键,Language Code的值是0,1,2,分别代表英语,繁体,简体。

字符串为界面控件标签上的文字,比如User Id, Department等。

为方便编辑字符串资源,增加一个存储过程,用于增加和修改语言资源:

SET QUOTED_IDENTIFIER ONSET ANSI_NULLS ONGOCREATE PROCEDURE [dbo].[spAddTranslationText]@KeyText nvarchar(200),@EnglishText nvarchar(200),@ChtText nvarchar(200),@ChsText nvarchar(200)ASBEGINSET NOCOUNT ON;SET @KeyText = UPPER(@KeyText)DELETE LanguageTranslation WHERE KEYTEXT = @KeyTextINSERT LanguageTranslation (LANGUAGECODE, KEYTEXT, DISPLAYTEXT, CREATEDDATE, CREATEDBY, REVISEDDATE, REVISEDBY)VALUES ('0', @KeyText, @EnglishText, GETDATE(), 'MIS', GETDATE(), 'MIS')INSERT LanguageTranslation (LANGUAGECODE, KEYTEXT, DISPLAYTEXT, CREATEDDATE, CREATEDBY, REVISEDDATE, REVISEDBY)VALUES ('1', @KeyText, @ChtText, GETDATE(), 'MIS', GETDATE(), 'MIS')INSERT LanguageTranslation (LANGUAGECODE, KEYTEXT, DISPLAYTEXT, CREATEDDATE, CREATEDBY, REVISEDDATE, REVISEDBY)VALUES ('2', @KeyText, @ChsText, GETDATE(), 'MIS', GETDATE(), 'MIS')ENDGO

为了简化简体到繁体的转化,调用.NET  VB类库中的方法,实现简体转化为繁体的功能,简体转化为繁体:

public string ConvertToTraditionalChinese(string label){    return Strings.StrConv(label, VbStrConv.TraditionalChinese, 0);}

基本上满足需求,转换的准确率不如Word或一些在线翻译工具。

将存储过程和语言转换的方法封装起来,做成一工具,输入要翻译的资源字符串和简体翻译,生成存储过程调用。

 

程序启动时,设计一个翻译资源缓存字典表,分别存放对应语言的键值对。

private static Dictionary
_cachedLanguageTranslation;

以下的代码从数据库中读取翻译数据到内存中,参考

DataTable languageTable = null;DbFunctionCall isNullDisplayText = new DbFunctionCall("ISNULL", new object[] { LanguageTranslationFields.DisplayText, string.Empty });EntityField2 displayTextField = new EntityField2("DisplayText", isNullDisplayText);ResultsetFields fields = new ResultsetFields(2);fields.DefineField(LanguageTranslationFields.KeyText, 0, "KeyText");fields.DefineField(displayTextField, 1, "DisplayText");ISortExpression sortExpression = new SortExpression(LanguageTranslationFields.KeyText | SortOperator.Ascending);using (DataAccessAdapterBase adapter = GetSystemDataAccessAdapter()){         languageTable = new FastSerializableDataTable();         languageTable.RemotingFormat = SerializationFormat.Binary;         IRelationPredicateBucket bucket = new RelationPredicateBucket();         bucket.PredicateExpression.Add(LanguageTranslationFields.LanguageCode == languageCode);         bucket.PredicateExpression.Add(displayTextField != string.Empty);         bucket.PredicateExpression.Add(LanguageTranslationFields.KeyText != displayTextField);         adapter.FetchTypedList(fields, languageTable, bucket, 0, sortExpression, false);
 

最后,设计一个公共接口方便调用:

//Shared.cspublic static string TranslateText(string textToTranslate){       return LanguageTranslator.TranslateText(textToTranslate);}

用数据库作为ERP多国语言实现方案有以下几个原因:

1  资源字符串可以被修改。这是最主要的原因,软件公司以程序员为主,没有实际的行业经验,不足以恰当(信,达,雅)的设计出各行业的翻译。产品发布到客户后,还可以修改资源字符串,不合理的地方以用户的经验为主。

2  资源字符串部署。以数据库表作为字符串资源的存储方式,部署时只需要发布SQL语句文件即可。

INSERT INTO [LanguageTranslation] ([LanguageCode],[KeyText],[DisplayText])VALUES(N'0', N'-- PRODUCTION REQ --', N'')INSERT INTO [LanguageTranslation] ([LanguageCode],[KeyText],[DisplayText])VALUES(N'0', N'-- LOC.TOTAL_QTY. --', N'')INSERT INTO [LanguageTranslation] ([LanguageCode],[KeyText],[DisplayText])VALUES(N'0', N'-- LOC TOTAL_QTY. --', N'')INSERT INTO [LanguageTranslation] ([LanguageCode],[KeyText],[DisplayText])VALUES(N'0', N'--- JOB ---', N'')INSERT INTO [LanguageTranslation] ([LanguageCode],[KeyText],[DisplayText])VALUES(N'0', N' DR ', N'')INSERT INTO [LanguageTranslation] ([LanguageCode],[KeyText],[DisplayText])VALUES(N'0', N' DISC. ALLOWED ', N'')INSERT INTO [LanguageTranslation] ([LanguageCode],[KeyText],[DisplayText])VALUES(N'0', N'-------------- DEMAND --------------', N'')

写完了多国语言实现方案,意犹未尽,去Google上搜索一下stackoverflow提供的解决方案,地址是

这篇问答中提到几个工具,这几个工具的网站都可以打开,读者若是在寻找多国语言方案,可实际操作体会一下。

  

 

 

 

转载地址:http://rvfql.baihongyu.com/

你可能感兴趣的文章
凡事预则立
查看>>
函数的定义域【基础辅导】
查看>>
Selenium 自动化验收测试
查看>>
Alpha冲刺随笔集
查看>>
站立会议04
查看>>
jquery 阻止默认事件(传播和冒泡)
查看>>
51Nod 1002 数字三角形 Label:水水水 && 非学习区警告
查看>>
基于Vue + webpack + Vue-cli 实现分环境打包项目
查看>>
shell编程===执行shell脚本的四种方法
查看>>
xv6操作系统学习笔记
查看>>
JAVA获取服务器路径的方法
查看>>
sys模块
查看>>
Gulp
查看>>
JS 常用 函数
查看>>
Oracle自动存储管理 ASMLib的支持变化
查看>>
hdu5079
查看>>
HttpUrlConnection的setDoOutput与setDoInput的区别
查看>>
Knockoutjs自学记录(一)~本地新建展示实例
查看>>
常量和数据类型
查看>>
javascript DOM操作
查看>>