Compartir vía


Table.SplitColumn

Sintaxis

Table.SplitColumn(
    table as table,
    sourceColumn as text,
    splitter as function,
    optional columnNamesOrNumber as any,
    optional default as any,
    optional extraColumns as any
) as table

Acerca de

Divide la columna especificada en un conjunto de columnas adicionales mediante la función divisora especificada.

  • table: tabla que contiene la columna que se va a dividir.
  • sourceColumn: nombre de la columna que se va a dividir.
  • splitter: la función divisora usada para dividir la columna (por ejemplo, Splitter.SplitTextByDelimiter o Splitter.SplitTextByPositions).
  • columnNamesOrNumber: una lista de nombres de columna nuevos que se van a crear o el número de columnas nuevas.
  • default: invalida el valor usado cuando no hay suficientes valores divididos para rellenar todas las columnas nuevas. El valor predeterminado de este parámetro es null.
  • extraColumns: especifica qué hacer si puede haber más valores divididos que el número de columnas nuevas. Puede pasar un ExtraValues.Type valor de enumeración a este parámetro. El valor predeterminado es ExtraValues.Ignore.

Ejemplo 1

Divida la columna nombre en nombre y apellido.

Uso

let
    Source = #table(type table[CustomerID = number, Name = text, Phone = text],
    {
        {1, "Bob White", "123-4567"},
        {2, "Jim Smith", "987-6543"},
        {3, "Paul", "543-7890"},
        {4, "Cristina Best", "232-1550"}
    }),
    SplitColumns = Table.SplitColumn(
        Source,
        "Name",
        Splitter.SplitTextByDelimiter(" "))
in
    SplitColumns

Salida

#table(type table[CustomerID = number, Name.1 = text, Name.2 = text, Phone = text],
{
    {1, "Bob", "White", "123-4567"},
    {2, "Jim", "Smith", "987-6543"},
    {3, "Paul", null, "543-7890"},
    {4, "Cristina", "Best", "232-1550"}
})

Ejemplo 2

Divida la columna de nombre en nombre y apellido, y luego renombre las nuevas columnas.

Uso

let
    Source = #table(type table[CustomerID = number, Name = text, Phone = text],
    {
        {1, "Bob White", "123-4567"},
        {2, "Jim Smith", "987-6543"},
        {3, "Paul", "543-7890"},
        {4, "Cristina Best", "232-1550"}
    }),
    SplitColumns = Table.SplitColumn(
        Source,
        "Name",
        Splitter.SplitTextByDelimiter(" "),
        {"First Name", "Last Name"})
in
    SplitColumns

Salida

#table(type table[CustomerID = number, First Name = text, Last Name = text, Phone = text],
{
    {1, "Bob", "White", "123-4567"},
    {2, "Jim", "Smith", "987-6543"},
    {3, "Paul", null, "543-7890"},
    {4, "Cristina", "Best", "232-1550"}
})

Ejemplo 3

Divida la columna nombre en nombre de pila y apellido, renombre las nuevas columnas y rellene los espacios en blanco con "-Sin Registro-".

Uso

let
    Source = #table(type table[CustomerID = number, Name = text, Phone = text],
    {
        {1, "Bob White", "123-4567"},
        {2, "Jim Smith", "987-6543"},
        {3, "Paul", "543-7890"},
        {4, "Cristina Best", "232-1550"}
    }),
    SplitColumns = Table.SplitColumn(
        Source,
        "Name",
        Splitter.SplitTextByDelimiter(" "),
        {"First Name", "Last Name"},
        "-No Entry-")
in
    SplitColumns

Salida

#table(type table[CustomerID = number, First Name = text, Last Name = text, Phone = text],
{
    {1, "Bob", "White", "123-4567"},
    {2, "Jim", "Smith", "987-6543"},
    {3, "Paul", "-No Entry-", "543-7890"},
    {4, "Cristina", "Best", "232-1550"}
})

Ejemplo 4

Divida la columna de nombre en nombre y apellido, y luego renombre las nuevas columnas. Dado que puede haber más valores que el número de columnas disponibles, convierta la columna de apellidos en una lista que incluya todos los valores después del nombre.

Uso

let
    Source = #table(type table[CustomerID = number, Name = text, Phone = text],
    {
        {1, "Bob White", "123-4567"},
        {2, "Jim Smith", "987-6543"},
        {3, "Paul Green", "543-7890"},
        {4, "Cristina J. Best", "232-1550"}
    }),
    SplitColumns = Table.SplitColumn(
        Source,
        "Name",
        Splitter.SplitTextByDelimiter(" "),
        {"First Name", "Last Name"},
        null,
        ExtraValues.List)
in
    SplitColumns

Salida

#table(type table[CustomerID = number, First Name = text, Last Name = text, Phone = text],
{
    {1, "Bob", {"White"}, "123-4567"},
    {2, "Jim", {"Smith"}, "987-6543"},
    {3, "Paul", {"Green"}, "543-7890"},
    {4, "Cristina", {"J.", "Best"}, "232-1550"}
})