Base de datos de ciudades Ejercicio VB.Net - Curso de Programación Visual Basic

 Ejercicio

Base de datos de ciudades

Objetivo

Cree una base de datos para almacenar información sobre las ciudades.

En un primer acercamiento, almacenaremos solo el nombre de cada ciudad y el número de habitantes, y asignaremos espacio para hasta 500 ciudades.

El menú debe incluir las siguientes opciones:
1.- Añadir una nueva ciudad (al final de los datos existentes)
2.- Ver todas las ciudades (nombre y habitantes)
3.- Modificar un registro (renombrar y/o cambiar número de habitantes)
4.- Insertar un nuevo registro (en una posición especificada, moviendo los siguientes a la derecha)
5.- Eliminar un registro (moviendo los siguientes a la izquierda para que no queden espacios vacíos)
6.- Buscar en los registros (mostrar los que contienen un determinado texto en su nombre, ya sea en mayúsculas o minúsculas, mediante búsqueda parcial)
7.- Corregir la mayúscula de los nombres (convertir en mayúscula la primera letra y las siguientes después de un espacio, y hacer el resto en minúsculas).
0.- Salida

Código

Imports System
Public Class exercise86
    Structure city
        Public name As String
        Public inhabitants As UInteger
    End Structure

    Public Shared Sub Main()
        Dim maxCities As Integer = 500
        Dim cities As city() = New city(maxCities - 1) {}
        Dim amount As Integer = 0
        Dim currentCityNumber As Integer
        Dim [option] As String
        Dim textToSearch As String
        Dim found As Boolean
        Dim textToModify As String
        Dim finished As Boolean = False

        Do
            Console.WriteLine()
            Console.WriteLine("Cities database")
            Console.WriteLine()
            Console.WriteLine("1.- Add a new city")
            Console.WriteLine("2.- View all cities")
            Console.WriteLine("3.- Modify a record")
            Console.WriteLine("4.- Insert a new record")
            Console.WriteLine("5.- Delete a record")
            Console.WriteLine("6.- Search in the records")
            Console.WriteLine("7.- Correct the capitalization of the names")
            Console.WriteLine("0.- Exit")
            Console.WriteLine()
            Console.Write("Choose an option: ")
            [option] = Console.ReadLine()

            Select Case [option]
                Case "0"
                    finished = True
                Case "1"

                    If amount > maxCities - 1 Then
                        Console.WriteLine("the database is full")
                    Else
                        Console.WriteLine("Entering data for city number {0}", amount + 1)
                        Console.Write("Enter the city name: ")
                        cities(amount).name = Console.ReadLine()
                        Console.Write("Enter the inhabitants numbers: ")
                        cities(amount).inhabitants = Convert.ToUInt32(Console.ReadLine())
                        Console.WriteLine("The data was entered correctly")
                        amount += 1
                    End If

                Case "2"

                    For i As Integer = 0 To amount - 1
                        Console.WriteLine("{0}: {1}, {2} inhabitants", i + 1, cities(i).name, cities(i).inhabitants)
                    Next

                    Console.WriteLine()
                Case "3"
                    Console.Write("Enter the city number: ")
                    currentCityNumber = Convert.ToInt32(Console.ReadLine())
                    Console.WriteLine("Enter a new data for a city number: {0}", currentCityNumber)
                    Console.Write("City name (was {0}; hit ENTER to leave as is): ", cities(currentCityNumber - 1).name)
                    textToModify = Console.ReadLine()
                    If textToModify <> "" Then cities(currentCityNumber - 1).name = textToModify
                    Console.Write("Inhabitants (was {0}; hit ENTER to leave as is): ", cities(currentCityNumber - 1).inhabitants)
                    textToModify = Console.ReadLine()
                    If textToModify <> "" Then cities(currentCityNumber - 1).inhabitants = Convert.ToUInt32(textToModify)
                    Console.WriteLine()
                Case "4"

                    If amount > maxCities - 1 Then
                        Console.WriteLine("The database is full")
                    Else
                        Console.Write("Enter the number of the city to modify: ")
                        currentCityNumber = Convert.ToInt32(Console.ReadLine())
                        Console.WriteLine("Insert a new data at {0} position: ", currentCityNumber)
                        amount += 1

                        For i As Integer = CInt(amount) To currentCityNumber - 1 + 1
                            cities(i) = cities(i - 1)
                        Next

                        Console.Write("City name: ")
                        cities(currentCityNumber - 1).name = Console.ReadLine()
                        Console.Write("Inhabitants: ")
                        cities(currentCityNumber - 1).inhabitants = Convert.ToUInt32(Console.ReadLine())
                    End If

                Case "5"
                    Console.Write("Enter the city number for delete: ")
                    currentCityNumber = Convert.ToInt32(Console.ReadLine())
                    Console.WriteLine("Deleting the number {0}", currentCityNumber)

                    For i As Integer = currentCityNumber - 1 To amount - 1
                        cities(i) = cities(i + 1)
                    Next

                    amount -= 1
                Case "6"
                    Console.Write("Enter the text to search: ")
                    textToSearch = Console.ReadLine()
                    found = False

                    For i As Integer = 0 To amount - 1

                        If cities(i).name.ToUpper().IndexOf(textToSearch.ToUpper()) >= 0 Then
                            Console.WriteLine("{0} found in {1}", textToSearch, cities(i).name)
                            found = True
                        End If
                    Next

                    If Not found Then Console.WriteLine("Not found.")
                Case "7"

                    For i As Integer = 0 To amount - 1
                        Dim lowerCaseName As String = cities(i).name.ToLower()
                        Dim correctedName As String = lowerCaseName.Substring(0, 1).ToUpper() & lowerCaseName.Substring(1)

                        For j As Integer = 1 To correctedName.Length - 2 - 1
                            If correctedName(j) = " "c Then correctedName = correctedName.Substring(0, j) & " " & correctedName.Substring(j + 1, 1).ToUpper() & correctedName.Substring(j + 2)
                        Next

                        cities(i).name = correctedName
                    Next

                Case Else
                    Console.WriteLine("Wrong option ")
            End Select
        Loop While Not finished
    End Sub
End Class

Más ejercicios Visual Basic (VB.Net) de Matrices, Estructuras y Cadenas

 Matriz inversa
Cree un programa en Visual Basic para pedir al usuario 5 números, guárdelos en una matriz y muéstrelos en orden inverso....
 Buscar en matriz
Cree un programa en Visual Basic que diga si un dato pertenece a una lista que se creó anteriormente.Los pasos a seguir son: - Preguntar al usuario...
 Matriz de números pares
Escriba un programa de Visual Basic para pedir al usuario 10 números enteros y mostrar los pares....
 Matriz de números positivos y negativos
Cree un programa de Visual Basic para pedir al usuario 10 números reales y mostrar el promedio de los positivos y el promedio de los negativos....
 Muchos números y suma
Cree un programa en Visual Basic que le pida al usuario varios números (hasta que ingrese "fin" y muestre su suma). Cuando la ejecución va a terminar,...
 Matriz bidimensional
Escriba un programa de Visual Basic para pedir al usuario las calificaciones de 20 alumnos (2 grupos de 10, utilizando una matriz bidimensional) y mue...
 Estadísticas V2
Crear un programa en Visual Basic estadístico que permita al usuario: - Añadir nuevos datos - Ver todos los datos introducidos - Buscar un artícu...
 Estructura
Crea una "estructura" para almacenar datos de puntos 2D. Los campos para cada punto serán: coordenada x (corta) y coordenada (corta) r (color roj...
 Matriz de estructura
Expanda el ejercicio anterior (punto de estructura), de modo que se puedan almacenar hasta 1.000 puntos, utilizando una "matriz de estructura". Pida a...
 Matriz de estructura y menú
Expanda el ejercicio anterior (matriz de puntos), de modo que muestre un menú, en el que el usuario puede elegir: - Añadir datos para un punto - M...
 Base de datos de libros
Cree una pequeña base de datos, que se utilizará para almacenar datos sobre libros. Para un determinado libro, queremos conservar la siguiente informa...
 Triángulo V2
Escriba un programa de Visual Basic para pedirle al usuario su nombre y muestre un triángulo con él, comenzando con 1 letra y creciendo hasta que teng...
 Rectángulo V3
Escriba un programa de Visual Basic para pedir al usuario su nombre y un tamaño, y muestre un rectángulo hueco con él: Introduce tu nombre: Yo Tam...
 Triángulo centrado
Mostrar un triángulo centrado a partir de una cadena introducida por el usuario: __a__ _uan_ Juan...
 Banner
Cree un programa de Visual Basic para imitar la utilidad básica de "banner" de Unix SysV, capaz de mostrar textos grandes....
 Triángulo lado derecho
Cree un programa en Visual Basic que solicite al usuario una cadena y muestre un triángulo alineado a la derecha: ____n ___an __uan Juan...
 Manipulación de cadenas
Cree un programa en Visual Basic que solicite al usuario una cadena y: - Sustituir todas las minúsculas A por mayúsculas A, excepto si van precedid...
 Estructuras anidadas
Cree una estructura para almacenar dos datos para una persona: nombre y fecha de nacimiento. La fecha de nacimiento debe ser otra estructura q...
 Ordenar datos
Cree un programa de Visual Basic para pedir al usuario 10 números enteros (de -1000 a 1000), ordenarlos y mostrarlos ordenados....
 Matriz bidimensional como búfer para pantalla
Cree un programa de Visual Basic que declare una matriz bidimensional de caracteres de 70x20, "dibuje" 80 letras (X, por ejemplo) en posiciones aleato...
 Matriz bidimensional 2: circunferencia en pantalla
Cree un programa de Visual Basic que declare que crea una matriz bidimensional de caracteres de 70x20, "dibuja" una circunferencia o radio 8 dentro de...
 Programas informáticos
Cree un programa de Visual Basic que pueda almacenar hasta 1000 registros de programas informáticos. Para cada programa, debe conservar los siguientes...
 Tareas de ejercicio
Crea un programa en Visual Basic que puede almacenar hasta 2000 "tareas pendientes". Para cada tarea, debe conservar los siguientes datos: • Fecha ...
 Cuentas del hogar
Cree un programa en Visual Basic que pueda almacenar hasta 10000 costos e ingresos, para crear un pequeño sistema de contabilidad nacional. Para cada ...

Juan A. Ripoll - Tutoriales de Sistemas y Cursos de Programación© 2025 Todos los derechos reservados.  Condiciones legales.