- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
请就 SonarQube 报告的问题提出小问题。
在一段非常简单的代码上:
Instant.now().atZone(ZoneId.systemDefault()).toLocalDateTime().format(DateTimeFormatter.ofPattern("yyyy-MM-dd-HH-mm-ss"))
我被标记了一些对我来说很奇怪的东西:i18n-java:V1009
Unicode ICU and not java.time.DateTimeFormatter should be used for international dates and times
Java's DateTimeFormatter is quite error prone prior to Java version 9. Version 9 and greater with Unicode CLDR data is much improved, but still has errors for key locales. For ideal results, use Unicode ICU DateTimePatternGenerator.
Noncompliant Code Example
Locale userPreferredLocale = Locale.forLanguageTag("zh-Hans");
...
DateTimeFormatter mediumFormatter = DateTimeFormatter.ofLocalizedDate(FormatStyle.MEDIUM).withLocale(userPreferredLocale);
Compliant Solution
import com.ibm.icu.text.DateTimePatternGenerator;
import com.ibm.icu.text.SimpleDateFormat;
import com.ibm.icu.util.ULocale;
...
ULocale userPreferredLocale = ULocale.forLanguageTag("zh-Hans");
...
DateTimePatternGenerator dtpg = DateTimePatternGenerator.getInstance(userPreferredLocale);
//pattern for com.ibm.icu.text.DateFormat.FULL="MMM DD,YYYY,h:mm A"
SimpleDateFormat sdf = new SimpleDateFormat(dtpg.getBestPattern("MMM dd, YYYY, h:mm A"), uloc);
我正在使用 Java 11,并希望避免导入此 IBM 包。我非常不确定当前的问题是什么(到目前为止代码工作正常)。
但我确实对解决这个问题很感兴趣。请问有实现它的“好方法”吗?
我会理解像这样的评论:“禁用SonarQube,禁用这个规则,不要太在意那些误报,不要太看重分析工具等等”
但我很感兴趣如何解决这个“Unicode ICU 而不是 java.time.DateTimeFormatter 应该用于国际日期和时间”。
谢谢
最佳答案
别担心。只需检查 DateTimeFormatter
生成的典型日期时间格式的文本在您支持的任何区域设置中满足您的用户的期望。如果是这样,则无需涉及 IBM 的 ICU 库。
让 java.time 自动本地化表示日期时间值的文本。
ZoneId ZoneId = ZoneId.of( "America/Montreal" ) ;
Locale locale = Locale.CANADA_FRENCH ;
ZonedDateTime zdt = ZonedDateTime.now( zoneId ) ;
DateTimeFormatter formatter = DateTimeFormatter.ofLocalizedDateTime( FormatStyle.FULL ).withLocale( locale ) ;
String output = zdt.format( formatter ) ;
仅供引用, Sonar 消息指的是 Unicode CLDR成为基于 OpenJDK 的 Java 实现中的默认语言环境资源适用于 Java 9 及更高版本。参见 JEP 252: Use CLDR Locale Data by Default . Java 10 带来了 further support .
你说:
I am quite unsure what is the current problem (code working fine so far).
我相信这不是代码工作的问题。
问题是本地化是否符合语言环境。
日期时间值的格式因人类语言、文化和亚文化而异。我们谈论的是翻译的单词,以及标点符号、缩写、元素顺序、大写等规则。跟踪所有这些本地化信息涉及大量数据。最重要的是,他们改变了。文化在变,学术界的理解也在变。
Java 8 及更早版本的 OpenJDK 中默认使用的此类语言环境数据的实现相对有限且肤浅,没有涵盖许多子文化。
相比之下,由 Unicode Consortium 管理的 CLDR 庞大且详细,涵盖许多亚文化。早期版本的 OpenJDK 包含 CLDR 的副本。但只有在 Java 9 中,它才成为默认的语言环境资源,并首先在那里进行查找。
也许 Sonar 消息说 java.time.DateTimeFormatter
在特定亚文化的细微差别方面存在一些问题。但我还没有听说过。如果您担心,可以查看 OpenJDK 问题跟踪器。
➥ 我不会担心。如果您知道您的应用程序将仅用于少数特定区域设置,请测试这些区域设置。从每个地区招募一组用户。查看您的应用程序的典型输出是否符合他们的期望。如果他们满意,请编写一些单元测试,然后收工。
请记住,正如我所说,文化规范会随着时间而改变。 Unicode 联盟跟踪这些变化,根据需要发布新版本的 CLDR。当您更新 Java 实现时,您可能会获得 CLDR 的更新版本。很可能某天在某些语言环境中生成表示日期时间的文本时可能会得到不同的输出。如果您可能关心这些变化,请编写我上面提到的那些单元测试。
仅供引用,Sonar 消息中提到的库是 International Components for Unicode (ICU) 的 Java 实现由 Taligent build 和 IBM ,现在位于 Unicode 联盟:http://site.icu-project.org/
关于java - 国际日期和时间应该使用 Unicode ICU 而不是 java.time.DateTimeFormatter,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/65514207/
我正在尝试学习 ICU 语法并希望能够表达在 ICU message format 中列出. 例如,给定数据: items: - cool - handy - neat 我希望能够生成如下
是否可以获得适当的大写,例如使用 ICU4C 的英文文本但没有构建任何自定义的非大写单词集?比如说,鉴于对峡湾的渴望,我希望获得对峡湾的渴望。 使用 ucasemap_utf8ToTitle() 和
我想编译 icu sqlite extension静态链接到 icu . 这是我试过的,也许错误对你来说是显而易见的。 > cd icu/source> ./runConfigureIcu Linux
我试图将我们 CI 环境中的 Node 版本从 Node 6 升级到 Node 8。我也更新了完整的 icu 版本。 $NODE_ICU_DATA 设置为 /usr/lib/node_modules/
我今天开始使用最新的 Android Build Tools (ABT) v19.0.3 收到消息。乍一看,我认为这可能是 ABT 的问题。然而,更仔细的调查显示这条消息: android.suppo
unicode 排序背后的理论是什么?我明白它是如何工作的,但我不明白为什么 they决定采用此标准进行归类排序。 似乎当您有两个字符串要比较时,例如使用 ucol_strcolliter(): uc
我的应用程序可能在一个列表中包含由不同字母/语言组成的字符串。我似乎无法找到有关对这些进行排序的正确方法应该是什么的任何信息,或者任何表明 ICU 支持此功能的迹象。 示例列表: 苹果 яблоко
如何在iPhone应用程序的工作区中使用ICU(Unicode国际组件)将sqlite编译为项目? 我之前已经编译了sqlite合并,但是我不确定应该下载哪些文件以及需要将哪些脚本添加到xcode中-
我正在尝试使用 ICU 音译器对某些文本进行非常具体的转换,如 here 所述. 我的文本包含半角片假名字符和常规拉丁字符。我想将半角片假名转换为全角片假名,同时保持非片假名字符不变。 我想简单地应用
有没有办法探测ICU library对于所有 UChar's表示库支持的货币符号? 我当前的解决方案是遍历所有语言环境并针对每个语言环境,执行如下操作: const DecimalFormatSymb
谁能解释为什么下面的比较不相等? void CompareTest() { UErrorCode status = U_ZERO_ERROR; UChar ruleset[500]; *rul
有没有办法探测 ICU最小面额的货币区域设置?例如,美国为 0.01 美元,韩国 (ko_KR) 为 ₩1。我想在 DecimalFormat object 上调用 getRoundingIncrem
我正在创建 SQLite3 的自定义构建,我想实现不区分大小写的文本列。 是否可以创建不区分大小写的排序规则? 最佳答案 你可能想调用 ucol_setStrength具有 UCOL_PRIMARY
我们有使用 ICU 库处理 Unicode 字符串的代码。当我们尝试构建它时,没有出现编译错误,但链接失败了。我用以下代码创建了一个小测试程序: #define U_STATIC_IMPLEMENTA
有人知道 ICU 字符集检测器的数据是如何构建的吗?添加其他语言是否困难? 例如,我在错误跟踪器中看到,自 2007 年以来就打开了检测泰语的票证,但直到今天都没有新内容。 谢谢 最佳答案 我会在 I
您好,我将我的sql语句修改为 CREATE VIRTUAL TABLE [v_fts] USING fts4 ( [title], tokenize=icu )" 但是当我尝试插入数据时出现错误
我的目标是逐个字符地迭代 Unicode 文本字符串,但下面的代码迭代的是代码单元而不是代码点,即使我使用的是 next32PostInc () 应该迭代代码点: void iterate_codep
是否可以在不退回到正则表达式的情况下使用 ICU 完成? 目前我规范化文件名是这样的: protected function normalizeFilename($filename) { $t
我了解 ICU 的本地化部分 - 日期、时间和货币格式、整理等。在消息翻译方面,我看到有人说 ICU 不提供消息翻译功能 - 例如查看 this SOF question . 但是,在查看 ICU 文
我想知道是否有一种方法可以在 ICU (c++) 库中引用字符串。存在 "\Q"+ string + "\E"但我生成的输入作为提供的字符串输入。似乎没有任何 ICU 引用正则表达式方法。只需将字符串
我是一名优秀的程序员,十分优秀!