草庐IT

c++ - Unicode 麻烦了! Ms-Access 97 迁移到 Ms-Access 2007

coder 2024-06-10 原文

问题分为两步:

问题步骤 1。访问包含以 UTF-8 编码的 XML 字符串的 97 数据库

问题归结为:Access 97 数据库包含以 UTF-8 编码的 XML 字符串。所以我创建了一个补丁工具,用于将 XML 字符串从 UTF-8 单独转换为 Unicode。为了将 UTF8 字符串转换为 Unicode,我使用了函数 MultiByteToWideChar(CP_UTF8, 0, PChar(OriginalName), -1, @newName, Size);.(其中 newName 是声明为“newName : Array[0..2048] of WideChar ;").

此功能在大多数情况下都适用,我已经用 Spainsh、Arabic 和字符对其进行了检查。但我正在研究希腊语和中文字符,这令人窒息。

对于某些希腊字符,例如“αÏ…γ. εαÏααβε1ε”(存储在 Access-97 中),生成的新字符串之间包含空字符,并且当它存储为宽字符串,字符被剪裁。

对于某些中文字符,如“?¢»?µ?”(存储在 Access-97 中),结果是完全荒谬的,如“?¢»?µ?”。

问题第 2 步。访问 97 db 文本字符串,应用程序 GUI 采用 unicode 输入并保存在 Access-97 中

首先我检查了阿拉伯语和西类牙文字符,似乎不需要明确的字符编码。但问题又出现在希腊字和中文字上。

我尝试了上面提到的相同的文本转换功能(是否正确???),结果再次令人失望。无需转换即可使用的 Spainsh 字符会导致 unicode 字符丢失或转换为常规 Ascii 字母。

希腊语和中文字符表现出与步骤 1 中提到的相似的行为。

请指导我。我采取的方法正确吗?还有别的办法吗??? 好吧,现在我很困惑,充满了问题:)

最佳答案

使用希腊字符没有特殊要求。真正的问题是字符存储在 Access 最初无法识别的编码中。当应用程序将 UTF8 值存储在数据库中时,它会尝试将每个字节转换为数据库代码页中的等效字节。每个在该编码中没有对应关系的字符都被替换为?这可能意味着希腊文本是可以的,而中文文本可能已经消失了。

为了将数据转换为可读的内容,您必须知道存储它们的代码页。使用它您可以获得实际的字节,然后将它们转换为 Unicode。

关于c++ - Unicode 麻烦了! Ms-Access 97 迁移到 Ms-Access 2007,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3186450/

有关c++ - Unicode 麻烦了! Ms-Access 97 迁移到 Ms-Access 2007的更多相关文章

  1. ruby-on-rails - unicode 字符串的长度 - 2

    在我的Rails(2.3,Ruby1.8.7)应用程序中,我需要将字符串截断到一定长度。该字符串是unicode,在控制台中运行测试时,例如'א'.length,我意识到返回了双倍长度。我想要一个与编码无关的长度,以便对unicode字符串或latin1编码字符串进行相同的截断。我已经了解了Ruby的大部分unicode资料,但仍然有些一头雾水。应该如何解决这个问题? 最佳答案 Rails有一个返回多字节字符的mb_chars方法。试试unicode_string.mb_chars.slice(0,50)

  2. ruby-on-rails - 如何优雅地重启 thin + nginx? - 2

    我的瘦服务器配置了nginx,我的ROR应用程序正在它们上运行。在我发布代码更新时运行thinrestart会给我的应用程序带来一些停机时间。我试图弄清楚如何优雅地重启正在运行的Thin实例,但找不到好的解决方案。有没有人能做到这一点? 最佳答案 #Restartjustthethinserverdescribedbythatconfigsudothin-C/etc/thin/mysite.ymlrestartNginx将继续运行并代理请求。如果您将Nginx设置为使用多个上游服务器,例如server{listen80;server

  3. 使用 ACL 调用 upload_file 时出现 Ruby S3 "Access Denied"错误 - 2

    我正在尝试编写一个将文件上传到AWS并公开该文件的Ruby脚本。我做了以下事情:s3=Aws::S3::Resource.new(credentials:Aws::Credentials.new(KEY,SECRET),region:'us-west-2')obj=s3.bucket('stg-db').object('key')obj.upload_file(filename)这似乎工作正常,除了该文件不是公开可用的,而且我无法获得它的公共(public)URL。但是当我登录到S3时,我可以正常查看我的文件。为了使其公开可用,我将最后一行更改为obj.upload_file(file

  4. ruby - 使用 `+=` 和 `send` 方法 - 2

    如何将send与+=一起使用?a=20;a.send"+=",10undefinedmethod`+='for20:Fixnuma=20;a+=10=>30 最佳答案 恐怕你不能。+=不是方法,而是语法糖。参见http://www.ruby-doc.org/docs/ProgrammingRuby/html/tut_expressions.html它说Incommonwithmanyotherlanguages,Rubyhasasyntacticshortcut:a=a+2maybewrittenasa+=2.你能做的最好的事情是:

  5. ruby - 如何计算 Liquid 中的变量 +1 - 2

    我对如何计算通过{%assignvar=0%}赋值的变量加一完全感到困惑。这应该是最简单的任务。到目前为止,这是我尝试过的:{%assignamount=0%}{%forvariantinproduct.variants%}{%assignamount=amount+1%}{%endfor%}Amount:{{amount}}结果总是0。也许我忽略了一些明显的东西。也许有更好的方法。我想要存档的只是获取运行的迭代次数。 最佳答案 因为{{incrementamount}}将输出您的变量值并且不会影响{%assign%}定义的变量,我

  6. arrays - Ruby 数组 += vs 推送 - 2

    我有一个数组数组,想将元素附加到子数组。+=做我想做的,但我想了解为什么push不做。我期望的行为(并与+=一起工作):b=Array.new(3,[])b[0]+=["apple"]b[1]+=["orange"]b[2]+=["frog"]b=>[["苹果"],["橙子"],["Frog"]]通过推送,我将推送的元素附加到每个子数组(为什么?):a=Array.new(3,[])a[0].push("apple")a[1].push("orange")a[2].push("frog")a=>[[“苹果”、“橙子”、“Frog”]、[“苹果”、“橙子”、“Frog”]、[“苹果”、“

  7. += 的 Ruby 方法 - 2

    有没有办法让Ruby能够做这样的事情?classPlane@moved=0@x=0defx+=(v)#thisiserror@x+=v@moved+=1enddefto_s"moved#{@moved}times,currentxis#{@x}"endendplane=Plane.newplane.x+=5plane.x+=10putsplane.to_s#moved2times,currentxis15 最佳答案 您不能在Ruby中覆盖复合赋值运算符。任务在内部处理。您应该覆盖+,而不是+=。plane.a+=b与plane.a=

  8. ruby - 在 Ruby 中将转义的 unicode (\u008E) 转换为重音字符 (Ž)? - 2

    我遇到了一个非常困难的时期:#containedwithin:"MA\u008EEIKIAI"#shouldbe"MAŽEIKIAI"#natureofstring$pstring3"MA\u008EEIKIAI"$putsstring3MAEIKIAI$string3.inspect"\"MA\\u008EEIKIAI\""$string3.bytes#关于从哪里开始的任何想法?注意:这不是我的previousquestion的副本. 最佳答案 \u008E表示代码点为8e(十六进制)的unicode字符出现在字符串中的那个位置。

  9. ruby-on-rails - Rails 2.3.5 : How does one access code inside of lib/directory/file. rb? - 2

    我创建了一个文件,这样我就可以在lib/foo/bar_woo.rb中的许多模型之间共享一个方法。在bar_woo.rb中,我定义了以下内容:moduleBarWoodefhelloputs"hello"endend然后在我的模型中我正在做类似的事情:defMyModel解释器提示它期望bar_woo.rb定义Foo::BarWoo。《使用Rails进行敏捷Web开发》一书指出,如果文件包含类或模块,并且文件使用类或模块名称的小写形式命名,那么Rails将自动加载文件。因此我不需要它。定义代码的正确方法是什么,在我的模型中调用代码的正确方法是什么? 最佳答案

  10. ruby - Sinatra + Heroku + Datamapper 使用 dm-sqlite-adapter 部署问题 - 2

    出于某种原因,heroku尝试要求dm-sqlite-adapter,即使它应该在这里使用Postgres。请注意,这发生在我打开任何URL时-而不是在gitpush本身期间。我构建了一个默认的Facebook应用程序。gem文件:source:gemcuttergem"foreman"gem"sinatra"gem"mogli"gem"json"gem"httparty"gem"thin"gem"data_mapper"gem"heroku"group:productiondogem"pg"gem"dm-postgres-adapter"endgroup:development,:t

随机推荐