Package google.type

索引

日期

表示整个或部分日历日期(例如生日)。一天中的时间和时区要么在别处指定,要么不重要。日期相对于公历。可以表示以下任一情况:

  • 包含非零年份、月份和天值的完整日期。
  • 月份和天,年份值为零(例如周年纪念日)。
  • 单独的年份,月份和天值为零。
  • 年份和月份,天值为零(例如,信用卡到期日期)。

相关类型:

字段
year

int32

日期中的年份。必须介于 1 到 9999 之间,或为 0(即指定不含年份的日期)。

month

int32

一年中的第几个月。必须介于 1 到 12 之间,或为 0(即只指定年份,不指定月份和天值)。

day

int32

一个月中的第几天。必须介于 1 到 31 之间并且对年份和月份有效,或为 0(即天不重要,指定单独的年份或者年份和月份)。

DayOfWeek

表示星期几。

枚举
DAY_OF_WEEK_UNSPECIFIED 未指定星期几。
MONDAY 星期一
TUESDAY 星期二
WEDNESDAY 星期三
THURSDAY 星期四
FRIDAY 星期五
SATURDAY 星期六
SUNDAY 星期日

间隔时间

表示时间间隔,编码为时间戳开始(含)和时间戳结束(不含)。

起始值必须小于或等于结束值。当开始时间等于结束时间时,间隔时间为空(与时间不匹配)。如果 start 和 end 均未指定,则间隔时间不限。

字段
start_time

Timestamp

可选。间隔的开始值(含)。

如果指定,则与此时间间隔匹配的时间戳必须相同或晚于开始时间。

end_time

Timestamp

可选。间隔结束时间(不含)。

如果指定,则与此时间间隔匹配的时间戳必须早于结束时间。

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()); }

参考文档:- https://github.com/google/libphonenumber

字段
extension

string

电话号码的分机号。该扩展在 ITU 建议中并未标准化,只不过被定义为一系列长度不超过 40 位的数字。除了数字之外,其他拨号字符可以存储在这里,例如“,”(表示等待)或“#”。

请注意,目前没有地区使用采用短号的分机号码,因此此字段通常只与 E.164 号码一起设置。它与 E.164 号码是分开保存的,以便将来可以进行短代码扩展。

联合字段 kind。必需。普通号码或短代码。将来可能会向以下某个字段添加新字段,因此,如果电话号码未设置任何编码字段,客户端应忽略未在其中设置任何字段的电话号码。kind 只能是下列其中一项:
e164_number

string

电话号码,以加号 ('+') 表示,后跟采用宽松的 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

一个短代码。

参考资料:- https://en.wikipedia.org/wiki/Short_code

ShortCode

表示短代码的对象,短号码通常比普通电话号码短得多,可用于处理彩信和短信系统中的消息,以及缩写拨号(例如,发送“发送文字 611 以查看套餐中剩余的分钟数。”)。

短号仅限一个地区使用,不能在国际上拨打。这意味着,不同的地区可以有相同的短号,但它们的用法和价格不同,即使这两个地区使用相同的国家/地区呼叫代码(例如美国和加拿大)也是如此。

字段
region_code

string

必需。可对此短代码进行调用的地区的 BCP-47 地区代码,例如“US”和“BB”。

参考资料:- http://www.unicode.org/reports/tr35/#unicode_region_subtag

number

string

必需。短号码,不含前导加号 ('+') 或国家/地区呼叫代码,例如“611”。

PostalAddress

表示邮政地址,例如邮政递送或付款地址。给定邮政地址时,邮政服务可以将物品投递到处所、邮政信箱或其他投递地点。此对象不模拟地理位置(道路、城镇、山区)。

在典型的使用场景中,地址将通过用户输入或导入现有数据来创建,具体取决于进程的类型。

有关输入/修改地址的建议:- 使用支持国际化的地址微件,例如 https://github.com/google/libaddressinput。不应向用户显示用于在使用某个字段的国家/地区之外输入或修改字段的界面元素。

如需详细了解如何使用此架构,请参阅:https://support.google.com/business/answer/6397478

字段
revision

int32

PostalAddress 的架构修订版本。必须将其设置为 0,也就是最新版本。

所有新版本必须向后兼容旧版本。

region_code

string

必需。地址的国家/地区的 CLDR 地区代码。系统不会推断此字段,该值由用户确保正确。如需了解详情,请参阅 https://cldr.unicode.org/https://www.unicode.org/cldr/charts/30/supplemental/territory_information.html。例如:瑞士的地区代码为“CH”。

language_code

string

可选。此地址内容的 BCP-47 语言代码(如果已知)。这通常是输入表单的界面语言,或者与地址的“国家/地区”中使用的某种语言或其转换后的其他语言相匹配。这可能会影响某些国家/地区的格式,但对数据的正确性并不重要,也不会影响任何验证或其他与格式无关的操作。

如果此值未知,则应省略(而不是指定可能不正确的默认值)。

示例:“zh-Hant”、“ja”、“ja-Latn”、“en”。

postal_code

string

可选。地址的邮政编码。并非所有国家/地区都使用或要求使用邮政编码,但在使用邮政编码时,它们可能会触发地址其他部分的额外验证(例如美国的州/邮政编码验证)。

sorting_code

string

可选。特定于国家/地区的额外排序代码。大多数区域都未使用此功能。在使用它的地方,此值可以是一个类似“CEDEX”的字符串,后面可能会跟一个数字(例如“CEDEX 7”),或者只有一个数字,代表“管制区代码”(牙买加),“投递区域指标”(马拉维)或“邮局指标”(例如科特迪瓦)。

administrative_area

string

可选。最高行政区划,用于国家或地区的邮政地址。例如,此值可以是州、省、州(俄罗斯)或县。具体来说,对于西班牙,此值为省而非自治区(例如此值为“巴塞罗那”而非“加泰罗尼亚”)。许多国家在邮政地址中不使用行政区划。例如对于瑞士,此字段应留空。

locality

string

可选。一般是指地址的城市/城镇部分。示例:美国的城市、意大利的市镇、英国的邮镇。对于没有明确定义 locality 或者其无法很好地对应这个结构的区域,应将 locality 留空并使用 address_lines。

sublocality

string

可选。地址的子级市行政区。例如,此值可以是社区、自治市/镇/区、行政区。

address_lines[]

string

描述详细地址的非结构化地址行。

由于 address_lines 中的值没有类型信息,并且有时可能在单个字段中包含多个值(例如“Austin, TX”),因此清楚的行顺序很重要。地址行的顺序应该是地址的国家/地区的“信封顺序”。在某些地方,此顺序有可能不同(例如日本),address_language 有助于使其明确(例如,“ja”表示从大到小排序,“ja-Latn”或“en”表示从小到大排序)。这样就可以根据语言选择地址的具体行。

地址的最小结构化表示形式由 region_code 和 address_lines 组成,其中所有其他信息都放在 address_lines 中。可以在没有地理编码的情况下非常近似地设置此地址的格式,但是在至少部分完成之前,不能对任何地址组成部分进行语义推理。

创建仅包含 region_code 和 address_lines 的地址,然后进行地理编码是处理完全非结构化地址的推荐方法(而不是猜测地址的哪些部分是城市/市镇或行政区)。

recipients[]

string

可选。此地址的收件人。在某些情况下,该字段可能包含多行信息。例如,它可能包含“转交”信息。

organization

string

可选。地址对应的组织的名称。

TimeOfDay

表示一天中的某个时间。日期和时区不重要,或在别处指定。API 可以选择允许闰秒。相关类型为 google.type.Dategoogle.protobuf.Timestamp

字段
hours

int32

一天中的小时(采用 24 小时制)。值应为 0 到 23。对于业务结束时间等场景,API 可以选择允许“24:00:00”一值。

minutes

int32

一天中某小时的分钟数。值必须是介于 0 和 59 之间的数字。

seconds

int32

时间的秒数部分。通常必须是介于 0 和 59 之间的数字。如果 API 允许闰秒,则 API 可以允许 60 一值。

nanos

int32

秒数的小数部分(以纳秒为单位)。值必须是介于 0 和 999999999 之间的数字。

TimeZone

表示 IANA 时区数据库中的时区。

字段
id

string

IANA 时区数据库中的时区,例如“America/New_York”。

version

string

可选。IANA 时区数据库版本号,例如“2019a”。