CursosEmpresasBlogLiveConfPrecios

Cláusula GroupBy

Clase 22 de 26 • Curso de Manejo de Datos en C# con LINQ

Clase anteriorSiguiente clase

Contenido del curso

Introducción
  • 1
    Bienvenida al curso

    Bienvenida al curso

    02:26
  • 2
    Prerrequisitos

    Prerrequisitos

    02:40
  • 3
    ¿Qué es LINQ?

    ¿Qué es LINQ?

    07:21
  • 4
    Programación declarativa vs. imperativa

    Programación declarativa vs. imperativa

    10:48
  • 5
    Utilizando LINQ por primera vez

    Utilizando LINQ por primera vez

    09:34
Configuración de proyecto
  • 6
    Creando el proyecto base

    Creando el proyecto base

    06:40
  • 7
    Configurando clases

    Configurando clases

    05:46
  • 8
    Importando datos

    Importando datos

    15:17
Operadores básicos
  • 9
    Usando el operador Where

    Usando el operador Where

    14:08
  • 10

    Ejercicio para aplicar el operador Where

    00:07
  • 11
    Operadores All y Any

    Operadores All y Any

    09:46
  • 12
    Operador Contains

    Operador Contains

    04:54
  • 13
    Operadores OrderBy y OrderByDescending

    Operadores OrderBy y OrderByDescending

    10:03
  • 14

    Ejercicio operador OrderBy

    00:00
  • 15
    Operadores Take y Skip

    Operadores Take y Skip

    14:52
  • 16
    Selección dinámica de datos

    Selección dinámica de datos

    09:33
Operadores de agregación
  • 17
    Operadores LongCount y Count

    Operadores LongCount y Count

    10:02
  • 18
    Operadores Min y Max

    Operadores Min y Max

    08:38
  • 19
    Operadores MinBy y MaxBy

    Operadores MinBy y MaxBy

    11:09
  • 20
    Operadores Sum y Aggregate

    Operadores Sum y Aggregate

    13:24
  • 21
    Operador Average

    Operador Average

    05:21
Agrupamiento de datos
  • 22
    Cláusula GroupBy

    Cláusula GroupBy

    07:33
  • 23

    Ejercicio cláusula GroupBy

    00:07
  • 24
    Cláusula Lookup

    Cláusula Lookup

    07:58
  • 25
    Cláusula Join

    Cláusula Join

    10:47
Cierre de curso
  • 26
    Recapitulación sobre LINQ

    Recapitulación sobre LINQ

    03:20
    Jimmy Alexander Soza Ortiz

    Jimmy Alexander Soza Ortiz

    student•
    hace 3 años

    Función usada para imprimir los agrupamientos por año

    void ImprimirGrupo(IEnumerable<IGrouping<int,Book>> ListadeLibros) { foreach(var grupo in ListadeLibros) { Console.WriteLine(""); Console.WriteLine($"Grupo: { grupo.Key }"); Console.WriteLine("{0,-60} {1, 15} {2, 15}\n", "Titulo", "N. Paginas", "Fecha publicacion"); foreach(var item in grupo) { Console.WriteLine("{0,-60} {1, 15} {2, 15}",item.Title,item.PageCount,item.PublishedDate.Date.ToShortDateString()); } } }
      Miguel Angel Reyes Moreno

      Miguel Angel Reyes Moreno

      student•
      hace 2 años
      heroe.jpg
    Jimmy Buriticá Londoño

    Jimmy Buriticá Londoño

    student•
    hace 3 años

    Cláusula GroupBy

    Permite agrupar los datos por una propiedad.

    Luca Cristian Manea

    Luca Cristian Manea

    student•
    hace 3 años

    Query public IEnumerable<IGrouping<int,Book>>booksAfter2000GroupByYearQuery(IEnumerable<Book>books){ return from b in books where b.PublishedDate.Year>=2000 group b by b.PublishedDate.Year; }

    Jerry Lee Minotta Rebellón

    Jerry Lee Minotta Rebellón

    student•
    hace 2 años

    Se puede modificar la función imprimirValores() que hemos estado usando para imprimir la lista de libros, para que reciba: un libro, una lista de libros o una lista de listas de libros (es lo que devuelve el groupBy):

    void printValues(IEnumerable<Book> listBooks, Book aBook, IEnumerable<IGrouping<int, Book>> ListBooksGrouped) { Console.WriteLine("{0,-60} {1,15} {2,15}\n", "Titulo", "N paginas", "Fecha Publicacion"); if (listBooks != null) { BookListPrint(listBooks); } else if (aBook != null) { Console.WriteLine("{0,-60} {1,15} {2,15}", aBook.Title, aBook.PageCount, aBook.PublishedDate.ToShortDateString()); } else if (ListBooksGrouped != null) { foreach (var group in ListBooksGrouped) { Console.WriteLine("\n Grupo: " + group.Key); BookListPrint(group); } } }

    Agregamos la funcion BookListPrint() para reutilizar algunas lineas de código que se repiten:

    void BookListPrint(IEnumerable<Book> listBooks) { foreach (Book book in listBooks) { Console.WriteLine("{0,-60} {1,15} {2,15}", book.Title, book.PageCount, book.PublishedDate.ToShortDateString()); } }

    Y finalmente llamamos la función pasando los(el) elementos que necesitamos y los demás en null:

    printValues(null, null, queries.AllBooksSince2000GruopByYear());
    Miguel Angel Reyes Moreno

    Miguel Angel Reyes Moreno

    student•
    hace 2 años

    Podemos poner el año como parámetro:

    public IEnumerable<IGrouping<int, Book>> LibrosAPartirDeAnioAgrupadosPorAnio(int anio) { return librosCollection.Where(book => book.PublishedDate.Year >= anio).OrderBy(book => book.PublishedDate).GroupBy(book => book.PublishedDate.Year); }

    //* Libros publicados a partir del 2000 agrupados por año ImprimirGrupo(queries.LibrosAPartirDeAnioAgrupadosPorAnio(2000));
    Joan Alexander Valerio Rodríguez

    Joan Alexander Valerio Rodríguez

    student•
    hace un año

    Les comparto mis ejercicios, también usando Query Expression:

    //Extension Method return BooksCollections .Where(p => p.PublishedDate.Year >= 2000) .GroupBy(p => p.PublishedDate.Year); //Query Expression var query = (from p in BooksCollections where p.PublishedDate.Year > 2000 select p).GroupBy(p => p.PublishedDate.Year); return query;
    Angel Qui

    Angel Qui

    student•
    hace 2 años
    void ImprimirGrupo(IEnumerable<IGrouping<int, Book>> ListaDeLibros) { foreach(var grupo in ListaDeLibros) { Console.WriteLine(""); Console.WriteLine($"*************** Año: {grupo.Key} ***************"); Console.WriteLine("{0,-60} {1, 15} {2, 15}\n", "Título", "N. Páginas", "Fecha publicación"); foreach(var item in grupo) { Console.WriteLine("{0,-60} {1, 15} {2, 15}", item.Title, item.PageCount, item.PublishedDate); } } } // retornar todos los libros que fueron publicados a partir del 2000 // agrupados por anio public IEnumerable<IGrouping<int, Book>> LibrosDespuesDel2000AgrupadosPorAno() { return librosCollection .Where(p => p.PublishedDate.Year >= 2000) .GroupBy(p => p.PublishedDate.Year); }
    Joel Angel David Barrantes Palacios

    Joel Angel David Barrantes Palacios

    student•
    hace 2 años

    Esta seria una mejor manera de ordenar los datos de los grupos:

    he usado ambas formas,

    public IEnumerable<IGrouping<int,Book>> GetBooksPublishedAndGroupByYear(int year) { //extension method // return CollectionBook // .Where(book => book.PublishedDate.Year >= year) // .OrderBy(book => book.PublishedDate.Year) // .ThenBy(book => book.PublishedDate.Month) // .GroupBy(book => book.PublishedDate.Year); //linq query return from book in CollectionBook where book.PublishedDate.Year >= year orderby book.PublishedDate.Year, book.PublishedDate.Month group book by book.PublishedDate.Year; }
    Ricardo Mejía

    Ricardo Mejía

    student•
    hace 3 años

    //AGREGANDO UN FILTRO MAS NUMERO DE PÁGINAS public IEnumerable<IGrouping<int,Book>> LibrosAgrupadosPorAno(){

    return libros.Where(p=>p.PublishedDate.Year>200 && p.PageCount>=100).GroupBy(p=>p.PublishedDate.Year); }

Escuelas

  • Desarrollo Web
    • Fundamentos del Desarrollo Web Profesional
    • Diseño y Desarrollo Frontend
    • Desarrollo Frontend con JavaScript
    • Desarrollo Frontend con Vue.js
    • Desarrollo Frontend con Angular
    • Desarrollo Frontend con React.js
    • Desarrollo Backend con Node.js
    • Desarrollo Backend con Python
    • Desarrollo Backend con Java
    • Desarrollo Backend con PHP
    • Desarrollo Backend con Ruby
    • Bases de Datos para Web
    • Seguridad Web & API
    • Testing Automatizado y QA para Web
    • Arquitecturas Web Modernas y Escalabilidad
    • DevOps y Cloud para Desarrolladores Web
  • English Academy
    • Inglés Básico A1
    • Inglés Básico A2
    • Inglés Intermedio B1
    • Inglés Intermedio Alto B2
    • Inglés Avanzado C1
    • Inglés para Propósitos Específicos
    • Inglés de Negocios
  • Marketing Digital
    • Fundamentos de Marketing Digital
    • Marketing de Contenidos y Redacción Persuasiva
    • SEO y Posicionamiento Web
    • Social Media Marketing y Community Management
    • Publicidad Digital y Paid Media
    • Analítica Digital y Optimización (CRO)
    • Estrategia de Marketing y Growth
    • Marketing de Marca y Comunicación Estratégica
    • Marketing para E-commerce
    • Marketing B2B
    • Inteligencia Artificial Aplicada al Marketing
    • Automatización del Marketing
    • Marca Personal y Marketing Freelance
    • Ventas y Experiencia del Cliente
    • Creación de Contenido para Redes Sociales
  • Inteligencia Artificial y Data Science
    • Fundamentos de Data Science y AI
    • Análisis y Visualización de Datos
    • Machine Learning y Deep Learning
    • Data Engineer
    • Inteligencia Artificial para la Productividad
    • Desarrollo de Aplicaciones con IA
    • AI Software Engineer
  • Ciberseguridad
    • Fundamentos de Ciberseguridad
    • Hacking Ético y Pentesting (Red Team)
    • Análisis de Malware e Ingeniería Forense
    • Seguridad Defensiva y Cumplimiento (Blue Team)
    • Ciberseguridad Estratégica
  • Liderazgo y Habilidades Blandas
    • Fundamentos de Habilidades Profesionales
    • Liderazgo y Gestión de Equipos
    • Comunicación Avanzada y Oratoria
    • Negociación y Resolución de Conflictos
    • Inteligencia Emocional y Autogestión
    • Productividad y Herramientas Digitales
    • Gestión de Proyectos y Metodologías Ágiles
    • Desarrollo de Carrera y Marca Personal
    • Diversidad, Inclusión y Entorno Laboral Saludable
    • Filosofía y Estrategia para Líderes
  • Diseño de Producto y UX
    • Fundamentos de Diseño UX/UI
    • Investigación de Usuarios (UX Research)
    • Arquitectura de Información y Usabilidad
    • Diseño de Interfaces y Prototipado (UI Design)
    • Sistemas de Diseño y DesignOps
    • Redacción UX (UX Writing)
    • Creatividad e Innovación en Diseño
    • Diseño Accesible e Inclusivo
    • Diseño Asistido por Inteligencia Artificial
    • Gestión de Producto y Liderazgo en Diseño
    • Diseño de Interacciones Emergentes (VUI/VR)
    • Desarrollo Web para Diseñadores
    • Diseño y Prototipado No-Code
  • Contenido Audiovisual
    • Fundamentos de Producción Audiovisual
    • Producción de Video para Plataformas Digitales
    • Producción de Audio y Podcast
    • Fotografía y Diseño Gráfico para Contenido Digital
    • Motion Graphics y Animación
    • Contenido Interactivo y Realidad Aumentada
    • Estrategia, Marketing y Monetización de Contenidos
  • Desarrollo Móvil
    • Fundamentos de Desarrollo Móvil
    • Desarrollo Nativo Android con Kotlin
    • Desarrollo Nativo iOS con Swift
    • Desarrollo Multiplataforma con React Native
    • Desarrollo Multiplataforma con Flutter
    • Arquitectura y Patrones de Diseño Móvil
    • Integración de APIs y Persistencia Móvil
    • Testing y Despliegue en Móvil
    • Diseño UX/UI para Móviles
  • Diseño Gráfico y Arte Digital
    • Fundamentos del Diseño Gráfico y Digital
    • Diseño de Identidad Visual y Branding
    • Ilustración Digital y Arte Conceptual
    • Diseño Editorial y de Empaques
    • Motion Graphics y Animación 3D
    • Diseño Gráfico Asistido por Inteligencia Artificial
    • Creatividad e Innovación en Diseño
  • Programación
    • Fundamentos de Programación e Ingeniería de Software
    • Herramientas de IA para el trabajo
    • Matemáticas para Programación
    • Programación con Python
    • Programación con JavaScript
    • Programación con TypeScript
    • Programación Orientada a Objetos con Java
    • Desarrollo con C# y .NET
    • Programación con PHP
    • Programación con Go y Rust
    • Programación Móvil con Swift y Kotlin
    • Programación con C y C++
    • Administración Básica de Servidores Linux
  • Negocios
    • Fundamentos de Negocios y Emprendimiento
    • Estrategia y Crecimiento Empresarial
    • Finanzas Personales y Corporativas
    • Inversión en Mercados Financieros
    • Ventas, CRM y Experiencia del Cliente
    • Operaciones, Logística y E-commerce
    • Gestión de Proyectos y Metodologías Ágiles
    • Aspectos Legales y Cumplimiento
    • Habilidades Directivas y Crecimiento Profesional
    • Diversidad e Inclusión en el Entorno Laboral
    • Herramientas Digitales y Automatización para Negocios
  • Blockchain y Web3
    • Fundamentos de Blockchain y Web3
    • Desarrollo de Smart Contracts y dApps
    • Finanzas Descentralizadas (DeFi)
    • NFTs y Economía de Creadores
    • Seguridad Blockchain
    • Ecosistemas Blockchain Alternativos (No-EVM)
    • Producto, Marketing y Legal en Web3
  • Recursos Humanos
    • Fundamentos y Cultura Organizacional en RRHH
    • Atracción y Selección de Talento
    • Cultura y Employee Experience
    • Gestión y Desarrollo de Talento
    • Desarrollo y Evaluación de Liderazgo
    • Diversidad, Equidad e Inclusión
    • AI y Automatización en Recursos Humanos
    • Tecnología y Automatización en RRHH
  • Finanzas e Inversiones
    • Fundamentos de Finanzas Personales y Corporativas
    • Análisis y Valoración Financiera
    • Inversión y Mercados de Capitales
    • Finanzas Descentralizadas (DeFi) y Criptoactivos
    • Finanzas y Estrategia para Startups
    • Inteligencia Artificial Aplicada a Finanzas
    • Domina Excel
    • Financial Analyst
    • Conseguir trabajo en Finanzas e Inversiones
  • Startups
    • Fundamentos y Validación de Ideas
    • Estrategia de Negocio y Product-Market Fit
    • Desarrollo de Producto y Operaciones Lean
    • Finanzas, Legal y Fundraising
    • Marketing, Ventas y Growth para Startups
    • Cultura, Talento y Liderazgo
    • Finanzas y Operaciones en Ecommerce
    • Startups Web3 y Blockchain
    • Startups con Impacto Social
    • Expansión y Ecosistema Startup
  • Cloud Computing y DevOps
    • Fundamentos de Cloud y DevOps
    • Administración de Servidores Linux
    • Contenerización y Orquestación
    • Infraestructura como Código (IaC) y CI/CD
    • Amazon Web Services
    • Microsoft Azure
    • Serverless y Observabilidad
    • Certificaciones Cloud (Preparación)
    • Plataforma Cloud GCP

Platzi y comunidad

  • Platzi Business
  • Live Classes
  • Lanzamientos
  • Executive Program
  • Trabaja con nosotros
  • Podcast

Recursos

  • Manual de Marca

Soporte

  • Preguntas Frecuentes
  • Contáctanos

Legal

  • Términos y Condiciones
  • Privacidad
  • Tyc promociones
Reconocimientos
Reconocimientos
Logo reconocimientoTop 40 Mejores EdTech del mundo · 2024
Logo reconocimientoPrimera Startup Latina admitida en YC · 2014
Logo reconocimientoPrimera Startup EdTech · 2018
Logo reconocimientoCEO Ganador Medalla por la Educación T4 & HP · 2024
Logo reconocimientoCEO Mejor Emprendedor del año · 2024
De LATAM conpara el mundo
YoutubeInstagramLinkedInTikTokFacebookX (Twitter)Threads