<?xml version="1.0" encoding="UTF-8"?>
<rss xmlns:content="http://purl.org/rss/1.0/modules/content/" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns:taxo="http://purl.org/rss/1.0/modules/taxonomy/" version="2.0">
  <channel>
    <title>topic Re: Script concatenate columns in Discussions</title>
    <link>https://community.jmp.com/t5/Discussions/Script-concatenate-columns/m-p/595131#M79882</link>
    <description>&lt;P&gt;This requires that the columns of interest are character columns, you have JMP16 and that the columns pass regex "Column \d{2}"&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;General idea&lt;/P&gt;
&lt;OL&gt;
&lt;LI&gt;Get list of column names&lt;/LI&gt;
&lt;LI&gt;Build a list of columns names you are interested in by using some filter (I'm using regex)&lt;/LI&gt;
&lt;LI&gt;Build expression for the formula with the list from 2.&lt;/LI&gt;
&lt;LI&gt;Use Eval(EvalExpr()) to add it to new column with a formula&lt;/LI&gt;
&lt;/OL&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-jsl"&gt;Names Default To Here(1);

dt = New Table("Untitled 2",
	Add Rows(0),
	Compress File When Saved(1),
	New Column("Column 1", Character, "Nominal", Set Values({"a"})),
	New Column("Column 2", Character, "Nominal", Set Values({"b"})),
	New Column("Column 10", Character, "Nominal", Set Values({"c"})),
	New Column("Column 11", Character, "Nominal", Set Values({"d"})),
	New Column("Column 12", Character, "Nominal", Set Values({"e"}))
);

col_names = dt &amp;lt;&amp;lt; Get Column Names(Character, "String");

list_expr = Expr(List());
For Each({col_name}, col_names,
	If(!IsMissing(Regex(col_name, "Column \d{2}")),
		Insert Into(list_expr, Name Expr(AsColumn(Column(dt, col_name))));
	);
);

// show(Name Expr(list_expr));

Eval(EvalExpr(
	dt &amp;lt;&amp;lt; New Column("PINNAME", Character, Nominal,
		Formula(Concat Items(Expr(list_expr), " "))
	);
));&lt;/CODE&gt;&lt;/PRE&gt;</description>
    <pubDate>Mon, 30 Jan 2023 17:54:18 GMT</pubDate>
    <dc:creator>jthi</dc:creator>
    <dc:date>2023-01-30T17:54:18Z</dc:date>
    <item>
      <title>Script concatenate columns</title>
      <link>https://community.jmp.com/t5/Discussions/Script-concatenate-columns/m-p/595093#M79879</link>
      <description>&lt;P&gt;Hello&lt;/P&gt;&lt;P&gt;I have written a script for&amp;nbsp;concatenating columns in column "PIN_NAME"&lt;/P&gt;&lt;P&gt;My problem is that I don't have a constant amount of columns.&lt;/P&gt;&lt;P&gt;I should concatenate column from Test_name 10 until Test_name 15, but some times I have just&amp;nbsp;Test_name 10 until&amp;nbsp;Test_name 13 (for example)&lt;/P&gt;&lt;P&gt;and I received an error because the script tries to concatenate Test_Name 14, and Test_Name 15 which don't exist.&lt;/P&gt;&lt;P&gt;Can you assist me with this issue?&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&lt;span class="lia-inline-image-display-wrapper lia-image-align-inline" image-alt="Dennisbur_0-1675098460791.png" style="width: 400px;"&gt;&lt;img src="https://community.jmp.com/t5/image/serverpage/image-id/49644i15554C771EFFFDD2/image-size/medium?v=v2&amp;amp;px=400" role="button" title="Dennisbur_0-1675098460791.png" alt="Dennisbur_0-1675098460791.png" /&gt;&lt;/span&gt;&lt;/P&gt;&lt;P&gt;Column(dt_split,"PIN_NAME") &amp;lt;&amp;lt; Formula(Char(:TEST_NAME 10 || " " ||&lt;BR /&gt;&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; :TEST_NAME 11 || " " ||&lt;BR /&gt;&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; :TEST_NAME 12 || " " ||&lt;BR /&gt;&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; :TEST_NAME 13 || " " ||&lt;BR /&gt;&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; :TEST_NAME 14 || " " ||&lt;BR /&gt;&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; :TEST_NAME 15)&lt;BR /&gt;);&lt;/P&gt;</description>
      <pubDate>Thu, 08 Jun 2023 16:39:48 GMT</pubDate>
      <guid>https://community.jmp.com/t5/Discussions/Script-concatenate-columns/m-p/595093#M79879</guid>
      <dc:creator>Dennisbur</dc:creator>
      <dc:date>2023-06-08T16:39:48Z</dc:date>
    </item>
    <item>
      <title>Re: Script concatenate columns</title>
      <link>https://community.jmp.com/t5/Discussions/Script-concatenate-columns/m-p/595131#M79882</link>
      <description>&lt;P&gt;This requires that the columns of interest are character columns, you have JMP16 and that the columns pass regex "Column \d{2}"&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;General idea&lt;/P&gt;
&lt;OL&gt;
&lt;LI&gt;Get list of column names&lt;/LI&gt;
&lt;LI&gt;Build a list of columns names you are interested in by using some filter (I'm using regex)&lt;/LI&gt;
&lt;LI&gt;Build expression for the formula with the list from 2.&lt;/LI&gt;
&lt;LI&gt;Use Eval(EvalExpr()) to add it to new column with a formula&lt;/LI&gt;
&lt;/OL&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-jsl"&gt;Names Default To Here(1);

dt = New Table("Untitled 2",
	Add Rows(0),
	Compress File When Saved(1),
	New Column("Column 1", Character, "Nominal", Set Values({"a"})),
	New Column("Column 2", Character, "Nominal", Set Values({"b"})),
	New Column("Column 10", Character, "Nominal", Set Values({"c"})),
	New Column("Column 11", Character, "Nominal", Set Values({"d"})),
	New Column("Column 12", Character, "Nominal", Set Values({"e"}))
);

col_names = dt &amp;lt;&amp;lt; Get Column Names(Character, "String");

list_expr = Expr(List());
For Each({col_name}, col_names,
	If(!IsMissing(Regex(col_name, "Column \d{2}")),
		Insert Into(list_expr, Name Expr(AsColumn(Column(dt, col_name))));
	);
);

// show(Name Expr(list_expr));

Eval(EvalExpr(
	dt &amp;lt;&amp;lt; New Column("PINNAME", Character, Nominal,
		Formula(Concat Items(Expr(list_expr), " "))
	);
));&lt;/CODE&gt;&lt;/PRE&gt;</description>
      <pubDate>Mon, 30 Jan 2023 17:54:18 GMT</pubDate>
      <guid>https://community.jmp.com/t5/Discussions/Script-concatenate-columns/m-p/595131#M79882</guid>
      <dc:creator>jthi</dc:creator>
      <dc:date>2023-01-30T17:54:18Z</dc:date>
    </item>
    <item>
      <title>Re: Script concatenate columns</title>
      <link>https://community.jmp.com/t5/Discussions/Script-concatenate-columns/m-p/595335#M79908</link>
      <description>&lt;P&gt;If you have Jmp17, things will be much easier.&lt;/P&gt;&lt;P&gt;Then you can call a function from &lt;STRONG&gt;New Formula Column&lt;/STRONG&gt; - no restriction to columns with type character :)&lt;/img&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;PRE&gt;&lt;CODE class=" language-jsl"&gt;Data Table( "Big Class" ) &amp;lt;&amp;lt; New Formula Column(
	Operation( Category( "Character" ), "Concatenate with Space" ),
	Columns( :name, :age, :sex, :height, :weight )
);&lt;/CODE&gt;&lt;/PRE&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Even better: you can even use variants which are disabled in the right click&amp;nbsp;&lt;STRONG&gt;New Formula Column&lt;/STRONG&gt;&amp;nbsp;menu.&lt;BR /&gt;&lt;LI-MESSAGE title="new formula column menu - don't disable variants" uid="595224" url="https://community.jmp.com/t5/JMP-Wish-List/new-formula-column-menu-don-t-disable-variants/m-p/595224#U595224" discussion_style_icon_css="lia-mention-container-editor-message lia-img-icon-idea-thread lia-fa-icon lia-fa-idea lia-fa-thread lia-fa"&gt;&lt;/LI-MESSAGE&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;like concatenation for numeric entries and counting of character column entries:&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;PRE&gt;&lt;CODE class=" language-jsl"&gt;Data Table( "Big Class" ) &amp;lt;&amp;lt; New Formula Column(
	Operation( Category( "Character" ), "Concatenate with Space" ),
	Columns( :height, :weight )
);

);
Data Table( "Big Class" ) &amp;lt;&amp;lt; New Formula Column(
	Operation( Category( "Aggregate" ), "Count" ),
	Columns( :name ),
	Group By( :sex )
);&lt;/CODE&gt;&lt;/PRE&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&lt;EM&gt;disabled in the right click&amp;nbsp;&lt;STRONG&gt;New Formula Column&lt;/STRONG&gt;&amp;nbsp;menu&lt;/EM&gt; - ARGH !!!!&lt;/P&gt;</description>
      <pubDate>Tue, 13 Aug 2024 17:14:35 GMT</pubDate>
      <guid>https://community.jmp.com/t5/Discussions/Script-concatenate-columns/m-p/595335#M79908</guid>
      <dc:creator>hogi</dc:creator>
      <dc:date>2024-08-13T17:14:35Z</dc:date>
    </item>
  </channel>
</rss>

