当前位置: 首页>>代码示例>>C#>>正文


C# PhoneNumbers.PhoneNumber类代码示例

本文整理汇总了C#中PhoneNumbers.PhoneNumber的典型用法代码示例。如果您正苦于以下问题:C# PhoneNumber类的具体用法?C# PhoneNumber怎么用?C# PhoneNumber使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。


PhoneNumber类属于PhoneNumbers命名空间,在下文中一共展示了PhoneNumber类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。

示例1: PhoneNumberMatch

 public PhoneNumberMatch(int start, String rawString, PhoneNumber number)
 {
     if (start < 0)
         throw new ArgumentException("Start index must be >= 0.");
     if (rawString == null || number == null)
         throw new ArgumentNullException();
     Start = start;
     RawString = rawString;
     Number = number;
 }
开发者ID:Grief-Code,项目名称:kilogram,代码行数:10,代码来源:PhoneNumberMatch.cs

示例2: GetNationalSignificantNumber

 /**
 * Gets the national significant number of the a phone number. Note a national significant number
 * doesn't contain a national prefix or any formatting.
 *
 * @param number  the PhoneNumber object for which the national significant number is needed
 * @return  the national significant number of the PhoneNumber object passed in
 */
 public String GetNationalSignificantNumber(PhoneNumber number)
 {
     // If a leading zero has been set, we prefix this now. Note this is not a national prefix.
     StringBuilder nationalNumber = new StringBuilder(number.ItalianLeadingZero ? "0" : "");
     nationalNumber.Append(number.NationalNumber);
     return nationalNumber.ToString();
 }
开发者ID:RanaInside,项目名称:libphonenumber-csharp,代码行数:14,代码来源:PhoneNumberUtil.cs

示例3: FormatNationalNumberWithPreferredCarrierCode

 /**
 * Formats a phone number in national format for dialing using the carrier as specified in the
 * preferredDomesticCarrierCode field of the PhoneNumber object passed in. If that is missing,
 * use the {@code fallbackCarrierCode} passed in instead. If there is no
 * {@code preferredDomesticCarrierCode}, and the {@code fallbackCarrierCode} contains an empty
 * string, return the number in national format without any carrier code.
 *
 * <p>Use {@link #formatNationalNumberWithCarrierCode} instead if the carrier code passed in
 * should take precedence over the number's {@code preferredDomesticCarrierCode} when formatting.
 *
 * @param number  the phone number to be formatted
 * @param fallbackCarrierCode  the carrier selection code to be used, if none is found in the
 *     phone number itself
 * @return  the formatted phone number in national format for dialing using the number's
 *     {@code preferredDomesticCarrierCode}, or the {@code fallbackCarrierCode} passed in if
 *     none is found
 */
 public String FormatNationalNumberWithPreferredCarrierCode(PhoneNumber number,
     String fallbackCarrierCode)
 {
     return FormatNationalNumberWithCarrierCode(number, number.HasPreferredDomesticCarrierCode
         ? number.PreferredDomesticCarrierCode
         : fallbackCarrierCode);
 }
开发者ID:RanaInside,项目名称:libphonenumber-csharp,代码行数:24,代码来源:PhoneNumberUtil.cs

示例4: FormatInOriginalFormat

        /**
        * Formats a phone number using the original phone number format that the number is parsed from.
        * The original format is embedded in the country_code_source field of the PhoneNumber object
        * passed in. If such information is missing, the number will be formatted into the NATIONAL
        * format by default. When the number contains a leading zero and this is unexpected for this
        * country, or we don't have a formatting pattern for the number, the method returns the raw input
        * when it is available.
        *
        * Note this method guarantees no digit will be inserted, removed or modified as a result of
        * formatting.
        *
        * @param number  the phone number that needs to be formatted in its original number format
        * @param regionCallingFrom  the region whose IDD needs to be prefixed if the original number
        *     has one
        * @return  the formatted phone number in its original number format
        */
        public String FormatInOriginalFormat(PhoneNumber number, String regionCallingFrom)
        {
            if (number.HasRawInput &&
                (HasUnexpectedItalianLeadingZero(number) || !HasFormattingPatternForNumber(number)))
            {
                // We check if we have the formatting pattern because without that, we might format the number
                // as a group without national prefix.
                return number.RawInput;
            }

            if (!number.HasCountryCodeSource)
                return Format(number, PhoneNumberFormat.NATIONAL);

            String formattedNumber;
            switch (number.CountryCodeSource)
            {
                case CountryCodeSource.FROM_NUMBER_WITH_PLUS_SIGN:
                    formattedNumber = Format(number, PhoneNumberFormat.INTERNATIONAL);
                    break;
                case CountryCodeSource.FROM_NUMBER_WITH_IDD:
                    formattedNumber = FormatOutOfCountryCallingNumber(number, regionCallingFrom);
                    break;
                case CountryCodeSource.FROM_NUMBER_WITHOUT_PLUS_SIGN:
                    formattedNumber = Format(number, PhoneNumberFormat.INTERNATIONAL).Substring(1);
                    break;
                case CountryCodeSource.FROM_DEFAULT_COUNTRY:
                    // Fall-through to default case.
                default:
                    String regionCode = GetRegionCodeForCountryCode(number.CountryCode);
                    // We strip non-digits from the NDD here, and from the raw input later, so that we can
                    // compare them easily.
                    String nationalPrefix = GetNddPrefixForRegion(regionCode, true /* strip non-digits */);
                    String nationalFormat = Format(number, PhoneNumberFormat.NATIONAL);
                    if (nationalPrefix == null || nationalPrefix.Length == 0)
                    {
                        // If the region doesn't have a national prefix at all, we can safely return the national
                        // format without worrying about a national prefix being added.
                        formattedNumber = nationalFormat;
                        break;
                    }
                    // Otherwise, we check if the original number was entered with a national prefix.
                    if (RawInputContainsNationalPrefix(
                        number.RawInput, nationalPrefix, regionCode))
                    {
                        // If so, we can safely return the national format.
                        formattedNumber = nationalFormat;
                        break;
                    }
                    PhoneMetadata metadata = GetMetadataForRegion(regionCode);
                    String nationalNumber = GetNationalSignificantNumber(number);
                    NumberFormat formatRule =
                        ChooseFormattingPatternForNumber(metadata.NumberFormatList, nationalNumber);
                    // When the format we apply to this number doesn't contain national prefix, we can just
                    // return the national format.
                    // TODO: Refactor the code below with the code in isNationalPrefixPresentIfRequired.
                    String candidateNationalPrefixRule = formatRule.NationalPrefixFormattingRule;
                    // We assume that the first-group symbol will never be _before_ the national prefix.
                    int indexOfFirstGroup = candidateNationalPrefixRule.IndexOf("${1}");
                    if (indexOfFirstGroup <= 0)
                    {
                        formattedNumber = nationalFormat;
                        break;
                    }
                    candidateNationalPrefixRule =
                        candidateNationalPrefixRule.Substring(0, indexOfFirstGroup);
                    candidateNationalPrefixRule = NormalizeDigitsOnly(candidateNationalPrefixRule);
                    if (candidateNationalPrefixRule.Length == 0)
                    {
                        // National prefix not used when formatting this number.
                        formattedNumber = nationalFormat;
                        break;
                    }
                    // Otherwise, we need to remove the national prefix from our output.
                    var numFormatCopy = new NumberFormat.Builder()
                        .MergeFrom(formatRule)
                        .ClearNationalPrefixFormattingRule()
                        .Build();
                    List<NumberFormat> numberFormats = new List<NumberFormat>(1);
                    numberFormats.Add(numFormatCopy);
                    formattedNumber = FormatByPattern(number, PhoneNumberFormat.NATIONAL, numberFormats);
                    break;
            }
            String rawInput = number.RawInput;
            // If no digit is inserted/removed/modified as a result of our formatting, we return the
//.........这里部分代码省略.........
开发者ID:RanaInside,项目名称:libphonenumber-csharp,代码行数:101,代码来源:PhoneNumberUtil.cs

示例5: Format

        /**
        * Same as {@link #format(PhoneNumber, PhoneNumberFormat)}, but accepts a mutable StringBuilder as
        * a parameter to decrease object creation when invoked many times.
        */
        public void Format(PhoneNumber number, PhoneNumberFormat numberFormat,
            StringBuilder formattedNumber)
        {
            // Clear the StringBuilder first.
            formattedNumber.Length = 0;
            var countryCallingCode = number.CountryCode;
            var nationalSignificantNumber = GetNationalSignificantNumber(number);
            if (numberFormat == PhoneNumberFormat.E164)
            {
                // Early exit for E164 case since no formatting of the national number needs to be applied.
                // Extensions are not formatted.
                formattedNumber.Append(nationalSignificantNumber);
                PrefixNumberWithCountryCallingCode(countryCallingCode, PhoneNumberFormat.E164,
                    formattedNumber);
                return;
            }
            // Note getRegionCodeForCountryCode() is used because formatting information for regions which
            // share a country calling code is contained by only one region for performance reasons. For
            // example, for NANPA regions it will be contained in the metadata for US.
            var regionCode = GetRegionCodeForCountryCode(countryCallingCode);
            if (!HasValidCountryCallingCode(countryCallingCode))
            {
                formattedNumber.Append(nationalSignificantNumber);
                return;
            }

            PhoneMetadata metadata = GetMetadataForRegionOrCallingCode(countryCallingCode, regionCode);
            formattedNumber.Append(FormatNsn(nationalSignificantNumber, metadata, numberFormat));
            MaybeAppendFormattedExtension(number, metadata, numberFormat, formattedNumber);
            PrefixNumberWithCountryCallingCode(countryCallingCode, numberFormat, formattedNumber);
        }
开发者ID:RanaInside,项目名称:libphonenumber-csharp,代码行数:35,代码来源:PhoneNumberUtil.cs

示例6: CanBeInternationallyDialled

 /**
 * Returns true if the number can be dialled from outside the region, or unknown. If the number
 * can only be dialled from within the region, returns false. Does not check the number is a valid
 * number.
 * TODO: Make this method public when we have enough metadata to make it worthwhile.
 *
 * @param number  the phone-number for which we want to know whether it is only diallable from
 *     outside the region
 */
 public bool CanBeInternationallyDialled(PhoneNumber number)
 {
     String regionCode = GetRegionCodeForNumber(number);
     if (!IsValidRegionCode(regionCode))
         // Note numbers belonging to non-geographical entities (e.g. +800 numbers) are always
         // internationally diallable, and will be caught here.
         return true;
     PhoneMetadata metadata = GetMetadataForRegion(regionCode);
     String nationalSignificantNumber = GetNationalSignificantNumber(number);
     return !IsNumberMatchingDesc(nationalSignificantNumber, metadata.NoInternationalDialling);
 }
开发者ID:RanaInside,项目名称:libphonenumber-csharp,代码行数:20,代码来源:PhoneNumberUtil.cs

示例7: MaybeAppendFormattedExtension

 /**
 * Appends the formatted extension of a phone number to formattedNumber, if the phone number had
 * an extension specified.
 */
 private void MaybeAppendFormattedExtension(PhoneNumber number, PhoneMetadata metadata,
     PhoneNumberFormat numberFormat, StringBuilder formattedNumber)
 {
     if (number.HasExtension && number.Extension.Length > 0)
     {
         if (numberFormat == PhoneNumberFormat.RFC3966)
         {
             formattedNumber.Append(RFC3966_EXTN_PREFIX).Append(number.Extension);
         }
         else
         {
             if (metadata.HasPreferredExtnPrefix)
                 formattedNumber.Append(metadata.PreferredExtnPrefix).Append(number.Extension);
             else
                 formattedNumber.Append(DEFAULT_EXTN_PREFIX).Append(number.Extension);
         }
     }
 }
开发者ID:RanaInside,项目名称:libphonenumber-csharp,代码行数:22,代码来源:PhoneNumberUtil.cs

示例8: HasUnexpectedItalianLeadingZero

 /**
 * Returns true if a number is from a region whose national significant number couldn't contain a
 * leading zero, but has the italian_leading_zero field set to true.
 */
 private bool HasUnexpectedItalianLeadingZero(PhoneNumber number)
 {
     return number.ItalianLeadingZero && !IsLeadingZeroPossible(number.CountryCode);
 }
开发者ID:RanaInside,项目名称:libphonenumber-csharp,代码行数:8,代码来源:PhoneNumberUtil.cs

示例9: IsValidNumber

 /**
 * Tests whether a phone number matches a valid pattern. Note this doesn't verify the number
 * is actually in use, which is impossible to tell by just looking at a number itself.
 *
 * @param number       the phone number that we want to validate
 * @return  a boolean that indicates whether the number is of a valid pattern
 */
 public bool IsValidNumber(PhoneNumber number)
 {
     var regionCode = GetRegionCodeForNumber(number);
     return IsValidNumberForRegion(number, regionCode);
 }
开发者ID:RanaInside,项目名称:libphonenumber-csharp,代码行数:12,代码来源:PhoneNumberUtil.cs

示例10: IsPossibleNumberWithReason

 /**
 * Check whether a phone number is a possible number. It provides a more lenient check than
 * {@link #isValidNumber} in the following sense:
 *<ol>
 * <li> It only checks the length of phone numbers. In particular, it doesn't check starting
 *      digits of the number.
 * <li> It doesn't attempt to figure out the type of the number, but uses general rules which
 *      applies to all types of phone numbers in a region. Therefore, it is much faster than
 *      isValidNumber.
 * <li> For fixed line numbers, many regions have the concept of area code, which together with
 *      subscriber number constitute the national significant number. It is sometimes okay to dial
 *      the subscriber number only when dialing in the same area. This function will return
 *      true if the subscriber-number-only version is passed in. On the other hand, because
 *      isValidNumber validates using information on both starting digits (for fixed line
 *      numbers, that would most likely be area codes) and length (obviously includes the
 *      length of area codes for fixed line numbers), it will return false for the
 *      subscriber-number-only version.
 * </ol
 * @param number  the number that needs to be checked
 * @return  a ValidationResult object which indicates whether the number is possible
 */
 public ValidationResult IsPossibleNumberWithReason(PhoneNumber number)
 {
     var nationalNumber = GetNationalSignificantNumber(number);
     int countryCode = number.CountryCode;
     // Note: For Russian Fed and NANPA numbers, we just use the rules from the default region (US or
     // Russia) since the getRegionCodeForNumber will not work if the number is possible but not
     // valid. This would need to be revisited if the possible number pattern ever differed between
     // various regions within those plans.
      if (!HasValidCountryCallingCode(countryCode))
         return ValidationResult.INVALID_COUNTRY_CODE;
     String regionCode = GetRegionCodeForCountryCode(countryCode);
     PhoneMetadata metadata = GetMetadataForRegionOrCallingCode(countryCode, regionCode);
     PhoneNumberDesc generalNumDesc = metadata.GeneralDesc;
     // Handling case of numbers with no metadata.
     if (!generalNumDesc.HasNationalNumberPattern)
     {
         int numberLength = nationalNumber.Length;
         if (numberLength < MIN_LENGTH_FOR_NSN)
             return ValidationResult.TOO_SHORT;
         if (numberLength > MAX_LENGTH_FOR_NSN)
             return ValidationResult.TOO_LONG;
         return ValidationResult.IS_POSSIBLE;
     }
     var possibleNumberPattern =
         regexCache.GetPatternForRegex(generalNumDesc.PossibleNumberPattern);
     return TestNumberLengthAgainstPattern(possibleNumberPattern, nationalNumber);
 }
开发者ID:RanaInside,项目名称:libphonenumber-csharp,代码行数:48,代码来源:PhoneNumberUtil.cs

示例11: IsPossibleNumber

 /**
 * Convenience wrapper around {@link #isPossibleNumberWithReason}. Instead of returning the reason
 * for failure, this method returns a boolean value.
 * @param number  the number that needs to be checked
 * @return  true if the number is possible
 */
 public bool IsPossibleNumber(PhoneNumber number)
 {
     return IsPossibleNumberWithReason(number) == ValidationResult.IS_POSSIBLE;
 }
开发者ID:RanaInside,项目名称:libphonenumber-csharp,代码行数:10,代码来源:PhoneNumberUtil.cs

示例12: IsNumberMatch

 /**
 * Takes two phone numbers and compares them for equality. This is a convenience wrapper for
 * {@link #isNumberMatch(PhoneNumber, PhoneNumber)}. No default region is known.
 *
 * @param firstNumber  first number to compare in proto buffer format.
 * @param secondNumber  second number to compare. Can contain formatting, and can have country
 *     calling code specified with + at the start.
 * @return  NOT_A_NUMBER, NO_MATCH, SHORT_NSN_MATCH, NSN_MATCH, EXACT_MATCH. See
 *     {@link #isNumberMatch(PhoneNumber, PhoneNumber)} for more details.
 */
 public MatchType IsNumberMatch(PhoneNumber firstNumber, String secondNumber)
 {
     // First see if the second number has an implicit country calling code, by attempting to parse
     // it.
     try
     {
         PhoneNumber secondNumberAsProto = Parse(secondNumber, UNKNOWN_REGION);
         return IsNumberMatch(firstNumber, secondNumberAsProto);
     }
     catch (NumberParseException e)
     {
         if (e.ErrorType == ErrorType.INVALID_COUNTRY_CODE)
         {
             // The second number has no country calling code. EXACT_MATCH is no longer possible.
             // We parse it as if the region was the same as that for the first number, and if
             // EXACT_MATCH is returned, we replace this with NSN_MATCH.
             String firstNumberRegion = GetRegionCodeForCountryCode(firstNumber.CountryCode);
             try
             {
                 if (!firstNumberRegion.Equals(UNKNOWN_REGION))
                 {
                     PhoneNumber secondNumberWithFirstNumberRegion = Parse(secondNumber, firstNumberRegion);
                     MatchType match = IsNumberMatch(firstNumber, secondNumberWithFirstNumberRegion);
                     if (match == MatchType.EXACT_MATCH)
                         return MatchType.NSN_MATCH;
                     return match;
                 }
                 else
                 {
                     // If the first number didn't have a valid country calling code, then we parse the
                     // second number without one as well.
                     var secondNumberProto = new PhoneNumber.Builder();
                     ParseHelper(secondNumber, null, false, false, secondNumberProto);
                     return IsNumberMatch(firstNumber, secondNumberProto.Build());
                 }
             }
             catch (NumberParseException)
             {
                 // Fall-through to return NOT_A_NUMBER.
             }
         }
     }
     // One or more of the phone numbers we are trying to match is not a viable phone number.
     return MatchType.NOT_A_NUMBER;
 }
开发者ID:RanaInside,项目名称:libphonenumber-csharp,代码行数:55,代码来源:PhoneNumberUtil.cs

示例13: GetRegionCodeForNumber

 /**
 * Returns the region where a phone number is from. This could be used for geocoding at the region
 * level.
 *
 * @param number  the phone number whose origin we want to know
 * @return  the region where the phone number is from, or null if no region matches this calling
 *     code
 */
 public String GetRegionCodeForNumber(PhoneNumber number)
 {
     List<String> regions = null;
     countryCallingCodeToRegionCodeMap_.TryGetValue(number.CountryCode, out regions);
     if (regions == null)
     {
         // String numberString = getNationalSignificantNumber(number);
         // LOGGER.log(Level.WARNING,
         //    "Missing/invalid country_code (" + countryCode + ") for number " + numberString);
         return null;
     }
     if (regions.Count == 1)
         return regions[0];
     return GetRegionCodeForNumberFromRegionList(number, regions);
 }
开发者ID:RanaInside,项目名称:libphonenumber-csharp,代码行数:23,代码来源:PhoneNumberUtil.cs

示例14: GetNumberType

 /**
 * Gets the type of a phone number.
 *
 * @param number  the phone number that we want to know the type
 * @return  the type of the phone number
 */
 public PhoneNumberType GetNumberType(PhoneNumber number)
 {
     var regionCode = GetRegionCodeForNumber(number);
     if (!IsValidRegionCode(regionCode) && !REGION_CODE_FOR_NON_GEO_ENTITY.Equals(regionCode))
         return PhoneNumberType.UNKNOWN;
     var nationalSignificantNumber = GetNationalSignificantNumber(number);
     PhoneMetadata metadata = GetMetadataForRegionOrCallingCode(number.CountryCode, regionCode);
     return GetNumberTypeHelper(nationalSignificantNumber, metadata);
 }
开发者ID:RanaInside,项目名称:libphonenumber-csharp,代码行数:15,代码来源:PhoneNumberUtil.cs

示例15: GetRegionCodeForNumberFromRegionList

 private String GetRegionCodeForNumberFromRegionList(PhoneNumber number,
     List<String> regionCodes)
 {
     String nationalNumber = GetNationalSignificantNumber(number);
     foreach (var regionCode in regionCodes)
     {
         // If leadingDigits is present, use this. Otherwise, do full validation.
         PhoneMetadata metadata = GetMetadataForRegion(regionCode);
         if (metadata.HasLeadingDigits)
         {
             if (regexCache.GetPatternForRegex(metadata.LeadingDigits)
                 .MatchBeginning(nationalNumber).Success)
                 return regionCode;
         }
         else if (GetNumberTypeHelper(nationalNumber, metadata) != PhoneNumberType.UNKNOWN)
             return regionCode;
     }
     return null;
 }
开发者ID:RanaInside,项目名称:libphonenumber-csharp,代码行数:19,代码来源:PhoneNumberUtil.cs


注:本文中的PhoneNumbers.PhoneNumber类示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。