- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试将 Java 字符转换为 JIS X 0208“x-JIS0208”编码(或任何兼容的编码,例如 EUC-JP,但不是 Shift-JIS),但我希望正确处理统一(合并)的代码点.
例如,高被分配给 this JISX0208 chart 中的第 25 行第 66 列,和一个看起来相似的字符髙,虽然被分类为未分配的代码点,但与前者合并。我引用维基百科:“[ ] (高) 形式和不太常见的梯状结构 (髙) 都包含在相同的代码点中”。
我在下面的代码中尝试了这一点,无论我尝试什么编码,我总是会遇到异常或未分配的字符占位符 ?
(ASCII 或全角)。
有没有办法,也许是不同的结尾或完全不同的转换方式,所以这两个字符返回相同的代码点?或者,是否有一个 API 可以查找此类字符,以便我可以在转换之前合并它们?
static Charset charset1 = Charset.forName("x-JIS0208");
static Charset charset2 = Charset.forName("EUC-JP");
static Charset[] charsets = {charset1, charset2};
static CharBuffer in = CharBuffer.allocate(1);
public static void main(String[] args) throws Exception
{
CharsetEncoder[] encoders = new CharsetEncoder[charsets.length];
for (int i = 0; i < charsets.length; i++)
encoders[i] = charsets[i].newEncoder();
char[] testChars = {' ', 'A', '?', '亜', '唖', '蔭', '高', '髙'};
for (char ch : testChars)
{
System.out.print("'" + ch + "'\t(" + Integer.toHexString(ch) + ")\t=");
for (int i = 0; i < charsets.length; i++)
{
System.out.print("\t" + interpret(encode1(encoders[i], ch)));
System.out.print("\t" + interpret(encode2(charsets[i], ch)));
}
System.out.println();
}
}
private static String interpret(int i)
{
if (i == -1)
return "excepti";
if (i < 0x80)
return "'" + (char)i + "'";
return Integer.toHexString(i);
}
private static int encode1(CharsetEncoder encoder, char ch)
{
in.rewind();
in.put(ch);
in.rewind();
try
{
ByteBuffer out = encoder.encode(in);
if (out.limit() == 1)
return out.get(0) & 0xFF;
return out.get(1) & 0xFF | (out.get(0) & 0xFF) << 8;
}
catch (CharacterCodingException e)
{
return -1;
}
}
private static int encode2(Charset charset, char ch)
{
in.rewind();
in.put(ch);
in.rewind();
ByteBuffer out = charset.encode(in);
if (out.limit() == 1)
return out.get(0) & 0xFF;
return out.get(1) & 0xFF | (out.get(0) & 0xFF) << 8;
}
输出:
' ' (3000) = 2121 2121 a1a1 a1a1
'A' (ff21) = 2341 2341 a3c1 a3c1
'?' (ff1f) = 2129 2129 a1a9 a1a9
'亜' (4e9c) = 3021 3021 b0a1 b0a1
'唖' (5516) = 3022 3022 b0a2 b0a2
'蔭' (852d) = 307e 307e b0fe b0fe
'高' (9ad8) = 3962 3962 b9e2 b9e2
'髙' (9ad9) = excepti 2129 excepti '?'
注意:我只对转换单个字符感兴趣,很多字符,而不是字符串或流,所以我实际上更喜欢一种不同的方法(如果存在),它不会在每次转换时分配 ByteBuffer。
最佳答案
髙不包含在 JIS X 0208 中,但包含在 Microsoft Windows 代码页 932 (MS932) 中。这是 Shift JIS 编码的变体,并且是 JIS X 0208 字符集的超集。您应该为 MS932 使用名称“Windows-31j”,例如:
Charset.forName("Windows-31j");
而不是Charset.forName("x-JIS0208");
。
一些字符如𨦇和铗(剪刀)的映射表是由日本政府分发的,如National Tax Agency (参见JIS缩退マップ(Ver.1.0.0)
)。但这些映射表不包含字符髙
。我认为这是因为髙
不包含在JIS X 0208和JIS X 0213中。
所以,我认为你必须手动将 髙
替换为 高
(使用 String#replaceAll()
),或者自己制作使用 CharsetProvider
自定义 Charset
。
关于java - JIS X 0208 转换 : how to handle unified (merged) codepoints,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11708099/
在 Java 中给定一个 String string,string.codePoints().toArray().length 是否反射(reflect) String 的长度人类会觉得有意义的实际字
尝试加载包含大约 700 万个三元组的 ntriples 文件时,我从 REST-API 收到以下错误: {"errorResponse":{"statusCode":500, "status":"I
我希望通过包含 unicode 字符的字符串字段对对象进行排序。但是,我想按代码点对字符串进行排序,而不是按区域设置。因此,这是一个示例,其中 JavaScript 对对象进行排序,以便 \u24B7
我正在尝试查看是否可以从 Julia 中的符号中检测到\dot 运算符,这是我尝试过的: 以下两个 block 返回不同的结果 julia> [codepoint(i) for i in string
s = "\u{d800}" 产生错误,test.rb:1: invalid Unicode codepoint,正如预期的那样。然而, begin s = "\u{d800}" rescue E
我正在使用 tiny-utf8 ,它作为 std::string 的直接替代品,但具有迭代 UTF-8 字符的能力。一切似乎都很好,但是,有时我的字符串会被其他库(在我的例子中是 RE2)以原始形式
在 ruby 1.9.3 中,我可以获得字符串的代码点: > "foo\u00f6".codepoints.to_a => [102, 111, 111, 246] 是否有一个内置的方法去另一个
这个问题在这里已经有了答案: If I use Java 8's String.codePoints to get an array of int codePoints, is it true th
我正在尝试将 Java 字符转换为 JIS X 0208“x-JIS0208”编码(或任何兼容的编码,例如 EUC-JP,但不是 Shift-JIS),但我希望正确处理统一(合并)的代码点. 例如,高
查看 Java 8 中的 String.chars() 方法,我们可以看到以下 javadoc : default IntStream chars() Returns a stream of int
如何使用 Unicode 名称在 Java 中查找字符或 int 代码点? 例如,如果 Character.getName('\u00e4') 返回 "LATIN SMALL LETTER A WIT
我是一名优秀的程序员,十分优秀!