1<p align="right"> 2<img src="https://travis-ci.org/google/libphonenumber.svg?branch=master"> 3</p> 4 5# What is it? 6 7Google's common Java, C++ and JavaScript library for parsing, formatting, and 8validating international phone numbers. The Java version is optimized for 9running on smartphones, and is used by the Android framework since 4.0 (Ice 10Cream Sandwich). 11 12# Quick links 13 14* **Reporting an issue?** Want to send a pull request? See the [contribution 15 guidelines](CONTRIBUTING.md) 16* Check the [frequently asked questions](FAQ.md) 17* Fun! [Falsehoods Programmers Believe About Phone Numbers](FALSEHOODS.md) 18* Look for 19 [`README`s](https://github.com/google/libphonenumber/find/master) in 20 directories relevant to the code you're interested in. 21* For contributors and porters: [How to run the Java demo](run-java-demo.md) 22* For porters: [How to make metadata changes](making-metadata-changes.md) 23 24# Highlights of functionality 25 26* Parsing, formatting, and validating phone numbers for all countries/regions 27 of the world. 28* `getNumberType` - gets the type of the number based on the number itself; 29 able to distinguish Fixed-line, Mobile, Toll-free, Premium Rate, Shared 30 Cost, VoIP, Personal Numbers, UAN, Pager, and Voicemail (whenever feasible). 31* `isNumberMatch` - gets a confidence level on whether two numbers could be 32 the same. 33* `getExampleNumber` and `getExampleNumberForType` - provide valid example 34 numbers for all countries/regions, with the option of specifying which type 35 of example phone number is needed. 36* `isPossibleNumber` - quickly guesses whether a number is a possible 37 phone number by using only the length information, much faster than a full 38 validation. 39* `isValidNumber` - full validation of a phone number for a region using 40 length and prefix information. 41* `AsYouTypeFormatter` - formats phone numbers on-the-fly when users enter 42 each digit. 43* `findNumbers` - finds numbers in text. 44* `PhoneNumberOfflineGeocoder` - provides geographical information related to 45 a phone number. 46* `PhoneNumberToCarrierMapper` - provides carrier information related to a 47 phone number. 48* `PhoneNumberToTimeZonesMapper` - provides timezone information related to a 49 phone number. 50 51# Demo 52 53## Java 54 55The [Java demo](https://libphonenumber.appspot.com/) is updated with a slight 56delay after the GitHub release. 57 58Last demo update: v8.12.47. 59 60If this number is lower than the [latest release's version 61number](https://github.com/google/libphonenumber/releases), we are between 62releases and the demo may be at either version. 63 64## JavaScript 65 66The [JavaScript 67demo](https://htmlpreview.github.io/?https://github.com/google/libphonenumber/blob/master/javascript/i18n/phonenumbers/demo-compiled.html) 68may be run at various tags; this link will take you to `master`. 69 70# Java code 71 72To include the Java code in your application, either integrate with Maven (see 73[wiki](https://github.com/google/libphonenumber/wiki)) or download the latest 74jars from the [Maven 75repository](https://repo1.maven.org/maven2/com/googlecode/libphonenumber/libphonenumber/). 76 77# Javadoc 78 79Javadoc is automatically updated to reflect the latest release at 80https://javadoc.io/doc/com.googlecode.libphonenumber/libphonenumber/. 81 82# Versioning and Announcements 83 84We generally choose the release number following these guidelines. 85 86If any of the changes pushed to master since the last release are incompatible 87with the intent / specification of an existing libphonenumber API or may cause 88libphonenumber (Java, C++, or JS) clients to have to change their code to keep 89building, we publish a major release. For example, if the last release were 907.7.3, the new one would be 8.0.0. 91 92If any of those changes *enable* clients to update their code to take advantage 93of new functionality, and if clients would have to roll-back these changes in 94the event that the release was marked as "bad", we publish a minor release. For 95example, we'd go from 7.7.3 to 7.8.0. 96 97Otherwise, including when a release contains only 98[metadata](FAQ.md#metadata_definition) changes, we publish a sub-minor release, 99e.g. 7.7.3 to 7.7.4. 100 101Sometimes we make internal changes to the code or metadata that, while not 102affecting compatibility for clients, could affect compatibility for **porters** 103of the library. For such changes we make announcements to 104[libphonenumber-discuss]( 105https://groups.google.com/forum/#!forum/libphonenumber-discuss). Such changes 106are not reflected in the version number, and we would publish a sub-minor 107release if there were no other changes. 108 109Want to get notified of new releases? During most of the year, excepting 110holidays and extenuating circumstances, we release fortnightly. We update 111[release tags](https://github.com/google/libphonenumber/releases) and 112document detailed [release notes]( 113https://github.com/google/libphonenumber/blob/master/release_notes.txt). 114We also send an announcement to [libphonenumber-discuss]( 115https://groups.google.com/forum/#!forum/libphonenumber-discuss) for every 116release. 117 118# Quick Examples 119 120Let's say you have a string representing a phone number from Switzerland. This 121is how you parse/normalize it into a `PhoneNumber` object: 122 123```java 124String swissNumberStr = "044 668 18 00"; 125PhoneNumberUtil phoneUtil = PhoneNumberUtil.getInstance(); 126try { 127 PhoneNumber swissNumberProto = phoneUtil.parse(swissNumberStr, "CH"); 128} catch (NumberParseException e) { 129 System.err.println("NumberParseException was thrown: " + e.toString()); 130} 131``` 132 133At this point, `swissNumberProto` contains: 134 135```json 136{ 137 "country_code": 41, 138 "national_number": 446681800 139} 140``` 141 142`PhoneNumber` is a class that was originally auto-generated from 143`phonenumber.proto` with necessary modifications for efficiency. For details on 144the meaning of each field, refer to `resources/phonenumber.proto`. 145 146Now let us validate whether the number is valid: 147 148```java 149boolean isValid = phoneUtil.isValidNumber(swissNumberProto); // returns true 150``` 151 152There are a few formats supported by the formatting method, as illustrated 153below: 154 155```java 156// Produces "+41 44 668 18 00" 157System.out.println(phoneUtil.format(swissNumberProto, PhoneNumberFormat.INTERNATIONAL)); 158// Produces "044 668 18 00" 159System.out.println(phoneUtil.format(swissNumberProto, PhoneNumberFormat.NATIONAL)); 160// Produces "+41446681800" 161System.out.println(phoneUtil.format(swissNumberProto, PhoneNumberFormat.E164)); 162``` 163 164You could also choose to format the number in the way it is dialed from another 165country: 166 167```java 168// Produces "011 41 44 668 1800", the number when it is dialed in the United States. 169System.out.println(phoneUtil.formatOutOfCountryCallingNumber(swissNumberProto, "US")); 170``` 171 172## Formatting Phone Numbers 'as you type' 173 174```java 175PhoneNumberUtil phoneUtil = PhoneNumberUtil.getInstance(); 176AsYouTypeFormatter formatter = phoneUtil.getAsYouTypeFormatter("US"); 177System.out.println(formatter.inputDigit('6')); // Outputs "6" 178... // Input more digits 179System.out.println(formatter.inputDigit('3')); // Now outputs "650 253" 180``` 181 182## Geocoding Phone Numbers 183 184```java 185PhoneNumberOfflineGeocoder geocoder = PhoneNumberOfflineGeocoder.getInstance(); 186// Outputs "Zurich" 187System.out.println(geocoder.getDescriptionForNumber(swissNumberProto, Locale.ENGLISH)); 188// Outputs "Zürich" 189System.out.println(geocoder.getDescriptionForNumber(swissNumberProto, Locale.GERMAN)); 190// Outputs "Zurigo" 191System.out.println(geocoder.getDescriptionForNumber(swissNumberProto, Locale.ITALIAN)); 192``` 193 194## Mapping Phone Numbers to original carriers 195 196Caveat: We do not provide data about the current carrier of a phone number, only 197the original carrier who is assigned the corresponding range. Read about [number 198portability](FAQ.md#what-is-mobile-number-portability). 199 200```java 201PhoneNumber swissMobileNumber = 202 new PhoneNumber().setCountryCode(41).setNationalNumber(798765432L); 203PhoneNumberToCarrierMapper carrierMapper = PhoneNumberToCarrierMapper.getInstance(); 204// Outputs "Swisscom" 205System.out.println(carrierMapper.getNameForNumber(swissMobileNumber, Locale.ENGLISH)); 206``` 207 208More examples on how to use the library can be found in the [unit 209tests](https://github.com/google/libphonenumber/tree/master/java/libphonenumber/test/com/google/i18n/phonenumbers). 210 211# Third-party Ports 212 213Several third-party ports of the phone number library are known to us. We share 214them here in case they're useful for developers. 215 216However, we emphasize that these ports are by developers outside the 217libphonenumber project. We do not evaluate their quality or influence their 218maintenance processes. 219 220* C#: https://github.com/twcclegg/libphonenumber-csharp 221* Go: https://github.com/nyaruka/phonenumbers 222* Objective-c: https://github.com/iziz/libPhoneNumber-iOS 223* PHP: https://github.com/giggsey/libphonenumber-for-php 224* PostgreSQL in-database types: https://github.com/blm768/pg-libphonenumber 225* Python: https://github.com/daviddrysdale/python-phonenumbers 226* Ruby: https://github.com/mobi/telephone_number 227* Rust: https://github.com/1aim/rust-phonenumber 228* Erlang: https://github.com/marinakr/libphonenumber_erlang 229* Clojure: https://github.com/randomseed-io/phone-number 230* R: https://github.com/socialresearchcentre/dialr/ 231 232Alternatives to our own versions: 233 234* Android-optimized: Our Java version loads the metadata from 235 `Class#getResourcesAsStream` and asks that Android apps follow the Android 236 loading best practices of repackaging the metadata and loading from 237 `AssetManager#open()` themselves 238 ([FAQ](https://github.com/google/libphonenumber/blob/master/FAQ.md#optimize-loads)). 239 If you don't want to do this, check out the port at 240 https://github.com/MichaelRocks/libphonenumber-android, which does repackage 241 the metadata and use `AssetManager#open()`, and may be depended on without 242 needing those specific loading optimizations from clients. You should also check 243 out the port at https://github.com/lionscribe/libphonenumber-android which also 244 supports geocoding, and only requires a one line code change. 245* Javascript: If you don't want to use our version, which depends on Closure, 246 there are several other options, including 247 https://github.com/catamphetamine/libphonenumber-js - a stripped-down 248 rewrite, about 110 KB in size - and 249 https://github.com/seegno/google-libphonenumber - a browserify-compatible 250 wrapper around the original unmodified library installable via npm, which 251 packs the Google Closure library, about 420 KB in size. 252