索引
Date
(消息)DayOfWeek
(枚举)Interval
(消息)PhoneNumber
(消息)PhoneNumber.ShortCode
(消息)PostalAddress
(消息)TimeOfDay
(消息)TimeZone
(消息)
日期
表示整个或部分日历日期(例如生日)。一天中的时间和时区要么在别处指定,要么不重要。日期相对于公历。可以表示以下任一情况:
- 包含非零年份、月份和天值的完整日期。
- 月份和天,年份值为零(例如周年纪念日)。
- 单独的年份,月份和天值为零。
- 年份和月份,天值为零(例如,信用卡到期日期)。
相关类型:
google.type.TimeOfDay
google.type.DateTime
google.protobuf.Timestamp
字段 | |
---|---|
year |
日期中的年份。必须介于 1 到 9999 之间,或为 0(即指定不含年份的日期)。 |
month |
一年中的第几个月。必须介于 1 到 12 之间,或为 0(即只指定年份,不指定月份和天值)。 |
day |
一个月中的第几天。必须介于 1 到 31 之间并且对年份和月份有效,或为 0(即天不重要,指定单独的年份或者年份和月份)。 |
DayOfWeek
表示星期几。
枚举 | |
---|---|
DAY_OF_WEEK_UNSPECIFIED |
未指定星期几。 |
MONDAY |
星期一 |
TUESDAY |
星期二 |
WEDNESDAY |
星期三 |
THURSDAY |
星期四 |
FRIDAY |
星期五 |
SATURDAY |
星期六 |
SUNDAY |
星期日 |
间隔时间
表示时间间隔,编码为时间戳开始(含)和时间戳结束(不含)。
起始值必须小于或等于结束值。当开始时间等于结束时间时,间隔时间为空(与时间不匹配)。如果 start 和 end 均未指定,则间隔时间不限。
字段 | |
---|---|
start_time |
可选。间隔的开始值(含)。 如果指定,则与此时间间隔匹配的时间戳必须相同或晚于开始时间。 |
end_time |
可选。间隔结束时间(不含)。 如果指定,则与此时间间隔匹配的时间戳必须早于结束时间。 |
PhoneNumber
一个表示电话号码的对象,适合采用 API 电汇格式。
此表示法:
不应用于根据区域设置的电话号码格式,如“+1 (650) 253-0000 分机号 123”
并非专为高效存储而设计
- 可能不适合拨打电话 - 应使用专门的电话库(请参阅参考信息)来解析号码
如需使用此数字执行有意义的操作(例如针对各种用例设置其格式),请先将其转换为 i18n.phonenumbers.PhoneNumber
对象。
例如,在 Java 中,代码为:
com.google.type.PhoneNumber wireProto = com.google.type.PhoneNumber.newBuilder().build(); com.google.i18n.phonenumbers.Phonenumber.PhoneNumber phoneNumber = PhoneNumberUtil.getInstance().parse(wireProto.getE164Number(), "ZZ"); if (!wireProto.getExtension().isEmpty()) { phoneNumber.setExtension(wireProto.getExtension()); }
字段 | |
---|---|
extension |
电话号码的分机号。该扩展在 ITU 建议中并未标准化,只不过被定义为一系列长度不超过 40 位的数字。除了数字之外,其他拨号字符可以存储在这里,例如“,”(表示等待)或“#”。 请注意,目前没有地区使用采用短号的分机号码,因此此字段通常只与 E.164 号码一起设置。它与 E.164 号码是分开保存的,以便将来可以进行短代码扩展。 |
联合字段 kind 。必需。普通号码或短代码。将来可能会向以下某个字段添加新字段,因此,如果电话号码未设置任何编码字段,客户端应忽略未在其中设置任何字段的电话号码。kind 只能是下列其中一项: |
|
e164_number |
电话号码,以加号 ('+') 表示,后跟采用宽松的 ITU E.164 格式的电话号码,由国家/地区呼叫代码(1 到 3 位)和用户号码组成,没有额外的空格或格式,例如:- 正确:“+15552220123”- 错误:“+1 (555) 222-01234 x123”。 ITU E.164 格式将后者限制为 12 位数字,但在实践中,并非所有国家/地区都遵循此格式,因此我们在此放宽了这一限制。不允许使用国内专用号码。 参考文献:- https://www.itu.int/rec/T-REC-E.164-201011-I - https://en.wikipedia.org/wiki/E.164。- https://en.wikipedia.org/wiki/List_of_country_calling_codes |
short_code |
一个短代码。 |
ShortCode
表示短代码的对象,短号码通常比普通电话号码短得多,可用于处理彩信和短信系统中的消息,以及缩写拨号(例如,发送“发送文字 611 以查看套餐中剩余的分钟数。”)。
短号仅限一个地区使用,不能在国际上拨打。这意味着,不同的地区可以有相同的短号,但它们的用法和价格不同,即使这两个地区使用相同的国家/地区呼叫代码(例如美国和加拿大)也是如此。
字段 | |
---|---|
region_code |
必需。可对此短代码进行调用的地区的 BCP-47 地区代码,例如“US”和“BB”。 参考资料:- http://www.unicode.org/reports/tr35/#unicode_region_subtag |
number |
必需。短号码,不含前导加号 ('+') 或国家/地区呼叫代码,例如“611”。 |
PostalAddress
表示邮政地址,例如邮政递送或付款地址。给定邮政地址时,邮政服务可以将物品投递到处所、邮政信箱或其他投递地点。此对象不模拟地理位置(道路、城镇、山区)。
在典型的使用场景中,地址将通过用户输入或导入现有数据来创建,具体取决于进程的类型。
有关输入/修改地址的建议:- 使用支持国际化的地址微件,例如 https://github.com/google/libaddressinput。不应向用户显示用于在使用某个字段的国家/地区之外输入或修改字段的界面元素。
如需详细了解如何使用此架构,请参阅:https://support.google.com/business/answer/6397478
字段 | |
---|---|
revision |
所有新版本必须向后兼容旧版本。 |
region_code |
必需。地址的国家/地区的 CLDR 地区代码。系统不会推断此字段,该值由用户确保正确。如需了解详情,请参阅 https://cldr.unicode.org/ 和 https://www.unicode.org/cldr/charts/30/supplemental/territory_information.html。例如:瑞士的地区代码为“CH”。 |
language_code |
可选。此地址内容的 BCP-47 语言代码(如果已知)。这通常是输入表单的界面语言,或者与地址的“国家/地区”中使用的某种语言或其转换后的其他语言相匹配。这可能会影响某些国家/地区的格式,但对数据的正确性并不重要,也不会影响任何验证或其他与格式无关的操作。 如果此值未知,则应省略(而不是指定可能不正确的默认值)。 示例:“zh-Hant”、“ja”、“ja-Latn”、“en”。 |
postal_code |
可选。地址的邮政编码。并非所有国家/地区都使用或要求使用邮政编码,但在使用邮政编码时,它们可能会触发地址其他部分的额外验证(例如美国的州/邮政编码验证)。 |
sorting_code |
可选。特定于国家/地区的额外排序代码。大多数区域都未使用此功能。在使用它的地方,此值可以是一个类似“CEDEX”的字符串,后面可能会跟一个数字(例如“CEDEX 7”),或者只有一个数字,代表“管制区代码”(牙买加),“投递区域指标”(马拉维)或“邮局指标”(例如科特迪瓦)。 |
administrative_area |
可选。最高行政区划,用于国家或地区的邮政地址。例如,此值可以是州、省、州(俄罗斯)或县。具体来说,对于西班牙,此值为省而非自治区(例如此值为“巴塞罗那”而非“加泰罗尼亚”)。许多国家在邮政地址中不使用行政区划。例如对于瑞士,此字段应留空。 |
locality |
可选。一般是指地址的城市/城镇部分。示例:美国的城市、意大利的市镇、英国的邮镇。对于没有明确定义 locality 或者其无法很好地对应这个结构的区域,应将 locality 留空并使用 address_lines。 |
sublocality |
可选。地址的子级市行政区。例如,此值可以是社区、自治市/镇/区、行政区。 |
address_lines[] |
描述详细地址的非结构化地址行。 由于 address_lines 中的值没有类型信息,并且有时可能在单个字段中包含多个值(例如“Austin, TX”),因此清楚的行顺序很重要。地址行的顺序应该是地址的国家/地区的“信封顺序”。在某些地方,此顺序有可能不同(例如日本),address_language 有助于使其明确(例如,“ja”表示从大到小排序,“ja-Latn”或“en”表示从小到大排序)。这样就可以根据语言选择地址的具体行。 地址的最小结构化表示形式由 region_code 和 address_lines 组成,其中所有其他信息都放在 address_lines 中。可以在没有地理编码的情况下非常近似地设置此地址的格式,但是在至少部分完成之前,不能对任何地址组成部分进行语义推理。 创建仅包含 region_code 和 address_lines 的地址,然后进行地理编码是处理完全非结构化地址的推荐方法(而不是猜测地址的哪些部分是城市/市镇或行政区)。 |
recipients[] |
可选。此地址的收件人。在某些情况下,该字段可能包含多行信息。例如,它可能包含“转交”信息。 |
organization |
可选。地址对应的组织的名称。 |
TimeOfDay
表示一天中的某个时间。日期和时区不重要,或在别处指定。API 可以选择允许闰秒。相关类型为 google.type.Date
和 google.protobuf.Timestamp
。
字段 | |
---|---|
hours |
一天中的小时(采用 24 小时制)。值应为 0 到 23。对于业务结束时间等场景,API 可以选择允许“24:00:00”一值。 |
minutes |
一天中某小时的分钟数。值必须是介于 0 和 59 之间的数字。 |
seconds |
时间的秒数部分。通常必须是介于 0 和 59 之间的数字。如果 API 允许闰秒,则 API 可以允许 60 一值。 |
nanos |
秒数的小数部分(以纳秒为单位)。值必须是介于 0 和 999999999 之间的数字。 |
TimeZone
表示 IANA 时区数据库中的时区。
字段 | |
---|---|
id |
IANA 时区数据库中的时区,例如“America/New_York”。 |
version |
可选。IANA 时区数据库版本号,例如“2019a”。 |