3

我正在开发一个包含多语言支持的网站。我可以使用 Zend_Translate 翻译字符串,但是内容呢?例如,我是否必须为每种语言的同一产品添加多个记录?或者还有其他方法吗?我是多语言新手,请帮忙。提前致谢。

- - 添加 - - - - - - - - - - - - - - -

好的,我决定使用混合解决方案来使用谷歌翻译 api 并将其存储在数据库中以供进一步编辑。那么存储翻译的数据库结构应该是什么???

  1. 我是否应该将不同语言的翻译保存在同一个表中作为父记录。即产品表中的产品,带有一个额外的标识语言列。
  2. 一个通用的单个表,用于存储所有表的所有翻译。例如翻译(id bigint,table_name vc(50),table_id bigint, langugae, column_name vc(50), translation)

我应该将记录保存在相关表中吗

4

1 回答 1

8

几种可能的方法:

  1. 使用gettext(或类似Poedit的软件)从内容中提取数据。可以使用可变插值。
  2. 创建视图过滤器,如:Zend Framework and Translation
  3. 在数据库中具有单独的数据内容。
    如果您以标记(例如Markdown)格式存储内容,任何人都可以轻松翻译它。创建不同语言的搜索引擎很容易。

似乎第三种方法需要最多的努力,但它是值得的。

评论后更新

我假设您将产品数据存储在数据库中,例如:

- product_data
-- id
-- price
-- name
-- description
-- etc…

所以你应该修改它,为每种语言的翻译字符串添加字段:

- product_data
-- id
-- price

- product_data_translations
-- product_id
-- language (e.g. en)
-- name
-- description
-- etc

然后,您可以轻松构建 SQL 查询来提取翻译后的数据where product_id=x and language="fr"

你也可以使用Doctrine I18N自动为你做这件事。

您需要手动翻译内容(或使用 Google API 自动翻译),然后,您可以使用Zend_Search_Lucene轻松索引它。

于 2010-10-30T06:33:28.570 回答