Cómo validar el número de GST (impuesto sobre bienes y servicios) mediante la expresión regular

Dada la string str , la tarea es verificar si la string dada es un número de GST (impuesto sobre bienes y servicios) válido o si no usa la expresión regular
El número válido de GST (impuesto sobre bienes y servicios) debe cumplir las siguientes condiciones: 

  1. Debe tener 15 caracteres de largo.
  2. Los primeros 2 caracteres deben ser un número.
  3. Los siguientes 10 caracteres deben ser el número de PAN del contribuyente.
  4. El decimotercer carácter (código de entidad) debe ser un número del 1 al 9 o un alfabeto.
  5. El carácter 14 debe ser Z.
  6. El decimoquinto carácter debe ser un alfabeto o un número.

Ejemplos: 

Entrada: str = “06BZAHM6385P6Z2”; 
Salida: verdadero 
Explicación: 
La string dada satisface todas las condiciones mencionadas anteriormente. Por lo tanto, es un número de GST (impuesto sobre bienes y servicios) válido.

Entrada: string = “06BZAF67”; 
Salida: falso 
Explicación: 
la string proporcionada no tiene 15 caracteres. Por lo tanto, no es un número GST (impuesto sobre bienes y servicios) válido.

Entrada: str = “AZBZAHM6385P6Z2”; 
Salida: falso 
Explicación: 
La string dada comienza con alfabeto. Por lo tanto, no es un número GST (impuesto sobre bienes y servicios) válido. 

Planteamiento: La idea es utilizar el concepto de Expresión Regular para resolver este problema. Se pueden seguir los siguientes pasos para calcular la respuesta: 

  • Consigue la cuerda.
  • Cree una expresión regular para verificar el número GST (Impuesto sobre bienes y servicios) válido como se menciona a continuación:

expresión regular = «^[0-9]{2}[AZ]{5}[0-9]{4}[AZ]{1}[1-9A-Z]{1}Z[0-9A-Z] {1}$”; 

  • Dónde: 
    • ^ representa el comienzo de la string.
    • [0-9]{2} representa que los primeros dos caracteres deben ser un número.
    • [AZ]{5} representa los siguientes cinco caracteres en mayúsculas.
    • [0-9]{4} representa que los siguientes cuatro caracteres deben ser cualquier número.
    • [AZ]{1} representa que el siguiente carácter debe ser cualquier alfabeto en mayúsculas.
    • [1-9A-Z]{1} representa el carácter número 13, debe ser un número del 1 al 9 o un alfabeto.
    • Z representa el carácter 14 que debe ser Z.
    • [0-9A-Z]{1} representa el decimoquinto carácter, debe ser un alfabeto o un número.
    • $ representa el final de la string.
  • Haga coincidir la string dada con la expresión regular. En Java, esto se puede hacer usando Pattern.matcher() .
  • Devuelve verdadero si la string coincide con la expresión regular dada; de lo contrario, devuelve falso.

A continuación se muestra la implementación del enfoque anterior:

Java

// Java program to validate the
// GST (Goods and Services Tax) number
// using regular expression.
 
import java.util.regex.*;
 
class GFG {
 
    // Function to validate
    // GST (Goods and Services Tax) number.
    public static boolean isValidGSTNo(String str)
    {
        // Regex to check valid
        // GST (Goods and Services Tax) number
        String regex = "^[0-9]{2}[A-Z]{5}[0-9]{4}"
                       + "[A-Z]{1}[1-9A-Z]{1}"
                       + "Z[0-9A-Z]{1}$";
 
        // Compile the ReGex
        Pattern p = Pattern.compile(regex);
 
        // If the string is empty
        // return false
        if (str == null)
        {
            return false;
        }
 
        // Pattern class contains matcher()
        // method to find the matching
        // between the given string
        // and the regular expression.
        Matcher m = p.matcher(str);
 
        // Return if the string
        // matched the ReGex
        return m.matches();
    }
 
    // Driver Code.
    public static void main(String args[])
    {
 
        // Test Case 1:
        String str1 = "06BZAHM6385P6Z2";
        System.out.println(isValidGSTNo(str1));
 
        // Test Case 2:
        String str2 = "06BZAF67";
        System.out.println(isValidGSTNo(str2));
 
        // Test Case 3:
        String str3 = "AZBZAHM6385P6Z2";
        System.out.println(isValidGSTNo(str3));
 
        // Test Case 4:
        String str4 = "06BZ63AHM85P6Z2";
        System.out.println(isValidGSTNo(str4));
 
        // Test Case 5:
        String str5 = "06BZAHM6385P6F2";
        System.out.println(isValidGSTNo(str5));
    }
}

Python3

# Python3 program to validate
# GST (Goods and Services Tax) number 
# using regular expression
import re
 
# Function to validate GST
# (Goods and Services Tax) number.
def isValidMasterCardNo(str):
 
    # Regex to check valid
    # GST (Goods and Services Tax) number
    regex = "^[0-9]{2}[A-Z]{5}[0-9]{4}" +
            "[A-Z]{1}[1-9A-Z]{1}" +
            "Z[0-9A-Z]{1}$"
     
    # Compile the ReGex
    p = re.compile(regex)
 
    # If the string is empty
    # return false
    if (str == None):
        return False
 
    # Return if the string
    # matched the ReGex
    if(re.search(p, str)):
        return True
    else:
        return False
 
# Driver code
 
# Test Case 1:
str1 = "06BZAHM6385P6Z2"
print(isValidMasterCardNo(str1))
 
# Test Case 2:
str2 = "06BZAF67"
print(isValidMasterCardNo(str2))
 
# Test Case 3:
str3 = "AZBZAHM6385P6Z2"
print(isValidMasterCardNo(str3))
 
# Test Case 4:
str4 = "06BZ63AHM85P6Z2"
print(isValidMasterCardNo(str4))
 
# Test Case 5:
str5 = "06BZAHM6385P6F2"
print(isValidMasterCardNo(str5))
 
# This code is contributed by avanitrachhadiya2155

C++

// C++ program to validate the
// GST (Goods and Services Tax) number
// using Regular Expression
#include <iostream>
#include <regex>
using namespace std;
 
// Function to validate the GST
// (Goods and Services Tax) number
bool isValidGSTNo(string str)
{
 
    // Regex to check valid GST
    // (Goods and Services Tax) number
    const regex pattern("^[0-9]{2}[A-Z]{5}"
                        "[0-9]{4}[A-Z]{1}["
                        "1-9A-Z]{1}Z[0-9A-Z]{1}$");
 
    // If the GST (Goods and Services Tax)
    // number is empty return false
    if (str.empty())
    {
        return false;
    }
 
    // Return true if the GST number
    // matched the ReGex
    if (regex_match(str, pattern))
    {
        return true;
    }
    else
    {
        return false;
    }
}
 
// Driver Code
int main()
{
    // Test Case 1:
    string str1 = "06BZAHM6385P6Z2";
    cout << isValidGSTNo(str1) << endl;
 
    // Test Case 2:
    string str2 = "06BZAF67";
    cout << isValidGSTNo(str2) << endl;
 
    // Test Case 3:
    string str3 = "AZBZAHM6385P6Z2";
    cout << isValidGSTNo(str3) << endl;
 
    // Test Case 4:
    string str4 = "06BZ63AHM85P6Z2";
    cout << isValidGSTNo(str4) << endl;
 
    // Test Case 5:
    string str5 = "06BZAHM6385P6F2";
    cout << isValidGSTNo(str5) << endl;
 
    return 0;
}
 
// This code is contributed by yuvraj_chandra
Producción

true
false
false
false
false

Publicación traducida automáticamente

Artículo escrito por prashant_srivastava y traducido por Barcelona Geeks. The original can be accessed here. Licence: CCBY-SA

Deja una respuesta

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *