cancel
Showing results for 
Show  only  | Search instead for 
Did you mean: 

Discussions

Solve problems, and share tips and tricks with other JMP users.
%3CLINGO-SUB%20id%3D%22lingo-sub-449088%22%20slang%3D%22en-US%22%20mode%3D%22UPDATE%22%3E%E6%A0%B9%E6%8D%AE%E6%9D%A1%E4%BB%B6%E5%86%8D%E6%B7%BB%E5%8A%A0%E4%B8%80%E5%88%97%E5%B9%B6%E5%AF%B9%E5%85%B6%E4%BB%96%E5%88%97%E8%BF%9B%E8%A1%8C%E5%88%86%E7%BB%84%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-449088%22%20slang%3D%22en-US%22%20mode%3D%22UPDATE%22%3E%3CP%3E%E5%A4%A7%E5%AE%B6%E5%A5%BD%EF%BC%8C%3CBR%20%2F%3E%E6%96%B0%E5%B9%B4%E5%BF%AB%E4%B9%90%EF%BC%8C%3CBR%20%2F%3E%E6%88%91%E5%8D%A1%E5%9C%A8%E5%8F%A6%E4%B8%80%E4%B8%AA%E5%9C%B0%E6%96%B9%EF%BC%8C%E6%9C%89%E6%83%B3%E6%B3%95%2F%E9%80%BB%E8%BE%91%EF%BC%8C%E4%BD%86%E6%97%A0%E6%B3%95%E8%BE%93%E5%85%A5%E6%AD%A3%E7%A1%AE%E7%9A%84%E5%85%AC%E5%BC%8F%E3%80%82%E8%AF%B7%E5%8F%82%E9%98%85%E9%99%84%E5%9B%BE%E7%9A%84%E8%AF%B4%E6%98%8E%E3%80%82%E8%BF%98%E9%99%84%E4%B8%8A%E4%BA%86%E6%A0%B7%E6%9C%AC%E6%95%B0%E6%8D%AE%E3%80%82%3CBR%20%2F%3E%3CBR%20%2F%3E%3C%2FP%3E%3CP%3E%3CSPAN%20class%3D%22lia-inline-image-display-wrapper%20lia-image-align-inline%22%20image-alt%3D%22HSS_1-1641371240772.png%22%20style%3D%22width%3A%20536px%3B%22%3E%3Cspan%20class%3D%22lia-inline-image-display-wrapper%22%20image-alt%3D%22HSS_1-1641371240772.png%22%20style%3D%22width%3A%20536px%3B%22%3E%3Cimg%20src%3D%22https%3A%2F%2Fcommunity.jmp.com%2Ft5%2Fimage%2Fserverpage%2Fimage-id%2F38741iB263FCFA4CCC9B20%2Fimage-dimensions%2F536x414%3Fv%3Dv2%22%20width%3D%22536%22%20height%3D%22414%22%20role%3D%22button%22%20title%3D%22HSS_1-1641371240772.png%22%20alt%3D%22HSS_1-1641371240772.png%22%20%2F%3E%3C%2Fspan%3E%3C%2FSPAN%3E%3C%2FP%3E%3CP%3E%20%3C%2FP%3E%3CP%3E%20%3C%2FP%3E%3CP%3E%E6%9C%89%E4%BB%80%E4%B9%88%E5%B8%AE%E5%8A%A9%E5%90%97%EF%BC%9F%3CBR%20%2F%3E%E9%9D%9E%E5%B8%B8%E6%84%9F%E8%B0%A2%E3%80%82%3C%2FP%3E%3C%2FLINGO-BODY%3E%3CLINGO-LABS%20id%3D%22lingo-labs-449088%22%20slang%3D%22en-US%22%20mode%3D%22UPDATE%22%3E%3CLINGO-LABEL%3E%E9%AB%98%E7%BA%A7%E7%BB%9F%E8%AE%A1%E5%BB%BA%E6%A8%A1%3C%2FLINGO-LABEL%3E%3CLINGO-LABEL%3E%E8%87%AA%E5%8A%A8%E5%8C%96%E5%92%8C%E8%84%9A%E6%9C%AC%E7%BC%96%E5%86%99%3C%2FLINGO-LABEL%3E%3CLINGO-LABEL%3E%E8%B4%A8%E9%87%8F%E5%92%8C%E5%B7%A5%E8%89%BA%E5%B7%A5%E7%A8%8B%3C%2FLINGO-LABEL%3E%3C%2FLINGO-LABS%3E%3CLINGO-SUB%20id%3D%22lingo-sub-449634%22%20slang%3D%22en-US%22%20mode%3D%22NONE%22%3E%E5%9B%9E%E5%A4%8D%EF%BC%9A%E6%A0%B9%E6%8D%AE%E6%9D%A1%E4%BB%B6%E5%86%8D%E6%B7%BB%E5%8A%A0%E4%B8%80%E5%88%97%E5%B9%B6%E5%9C%A8%E5%85%B6%E4%BB%96%E5%88%97%E4%B8%8A%E5%88%86%E7%BB%84%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-449634%22%20slang%3D%22en-US%22%20mode%3D%22NONE%22%3E%3CP%3E%E8%B0%A2%E8%B0%A2%E5%BC%97%E5%85%B0%E5%85%8B%E3%80%82%3CBR%20%2F%3E%3CBR%20%2F%3E%E6%9C%89%E6%95%88%E3%80%82%3C%2FP%3E%3C%2FLINGO-BODY%3E%3CLINGO-SUB%20id%3D%22lingo-sub-449324%22%20slang%3D%22en-US%22%20mode%3D%22NONE%22%3E%E5%9B%9E%E5%A4%8D%EF%BC%9A%E6%A0%B9%E6%8D%AE%E6%9D%A1%E4%BB%B6%E5%86%8D%E6%B7%BB%E5%8A%A0%E4%B8%80%E5%88%97%E5%B9%B6%E5%9C%A8%E5%85%B6%E4%BB%96%E5%88%97%E4%B8%8A%E5%88%86%E7%BB%84%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-449324%22%20slang%3D%22en-US%22%20mode%3D%22NONE%22%3E%3CP%3E%E5%97%A8HSS%3C%2FP%3E%3CP%3E%E6%88%91%E8%AE%A4%E4%B8%BA%E9%9C%80%E8%A6%81%E5%81%9A%203%20%E4%B8%AA%E6%AD%A5%E9%AA%A4%E6%89%8D%E8%83%BD%E6%BB%A1%E8%B6%B3%E6%82%A8%E7%9A%84%E9%9C%80%E6%B1%82%E3%80%82%3C%2FP%3E%3CP%3E1.%20%E6%B1%87%E6%80%BB%E6%82%A8%E7%9A%84%E6%95%B0%E6%8D%AE%E8%A1%A8%E4%BB%A5%E8%BF%9B%E8%A1%8C%E6%98%A0%E5%B0%84%E3%80%82%20%E7%B4%A2%E5%BC%95%E6%98%AF%E2%80%9C%E4%BC%A0%E6%84%9F%E5%99%A8%E2%80%9D%EF%BC%8C%E5%80%BC%E6%98%AF%E2%80%9C%E6%9C%80%E5%A4%A7%EF%BC%88%E5%85%A5%E5%8F%A3%EF%BC%89%EF%BC%8C%E6%9C%80%E5%A4%A7%EF%BC%88%E8%BF%94%E5%9B%9E%EF%BC%89%E2%80%9D%E3%80%82%3C%2FP%3E%3CP%3E%2F%2F%E5%8F%AF%E4%BB%A5%E4%BD%BF%E7%94%A8%E4%B8%8B%E9%9D%A2%E7%9A%84JSL%E6%9D%A5%E6%B1%87%E6%80%BB%E4%B8%80%E4%B8%AA%E6%96%B0%E7%9A%84%E6%95%B0%E6%8D%AE%E8%A1%A8%3C%2FP%3E%3CPRE%3E%3CCODE%20class%3D%22%20language-jsl%22%3EData%20Table(%20%22Data%22%20)%20%26lt%3B%26lt%3B%20Summary(%0A%20Group(%20%3ASensor%20)%2C%0A%20Max(%20%3AOccurrence%20)%2C%0A%20Subgroup(%20%3AName(%20%22Sub-Sensor%22%20)%20)%2C%0A%20Freq(%20%22None%22%20)%2C%0A%20Weight(%20%22None%22%20)%2C%0A%20statistics%20column%20name%20format(%20%22column%22%20)%0A)%3B%3C%2FCODE%3E%3C%2FPRE%3E%3CP%3E2.%20%E9%80%9A%E8%BF%87%20if%20%E6%88%96%20match%20%E8%BE%93%E5%85%A5%E6%82%A8%E7%9A%84%E6%9D%A1%E4%BB%B6%E3%80%82%20%E5%9C%A8%E8%BF%99%E9%87%8C%EF%BC%8C%E6%88%91%E4%BD%BF%E7%94%A8%E4%BA%86%20If%20%E5%B9%B6%E5%9C%A8%E6%B1%87%E6%80%BB%E6%95%B0%E6%8D%AE%E8%A1%A8%E4%B8%AD%E5%88%9B%E5%BB%BA%E4%BA%86%E4%B8%80%E4%B8%AA%E6%96%B0%E5%88%97%E3%80%82%3C%2FP%3E%3CPRE%3E%3CCODE%20class%3D%22%20language-jsl%22%3EIf(%0A%20%3AName(%20%22Occurrence%2C%20Inlet%22%20)%20%26gt%3B%3D%202%20%26amp%3B%20%3AName(%20%22Occurrence%2C%20Return%22%20)%20%26gt%3B%3D%202%2C%20%22Both%22%2C%0A%20%3AName(%20%22Occurrence%2C%20Inlet%22%20)%20%26gt%3B%3D%202%20%26amp%3B%20%3AName(%20%22Occurrence%2C%20Return%22%20)%20%26lt%3B%202%2C%20%22Inlet%22%2C%0A%20%3AName(%20%22Occurrence%2C%20Inlet%22%20)%20%26lt%3B%202%20%26amp%3B%20%3AName(%20%22Occurrence%2C%20Return%22%20)%20%26gt%3B%3D%202%2C%20%22Return%22%2C%0A%20%22Empty%22%0A)%3B%3C%2FCODE%3E%3C%2FPRE%3E%3CP%3E3.%E9%80%9A%E8%BF%87%E2%80%9C%E4%BC%A0%E6%84%9F%E5%99%A8%E2%80%9D%E5%B0%86%E4%B8%A4%E4%B8%AA%E6%95%B0%E6%8D%AE%E8%A1%A8%E8%BF%9E%E6%8E%A5%E5%9C%A8%E4%B8%80%E8%B5%B7%EF%BC%8C%E5%B9%B6%E7%A1%AE%E4%BF%9D%E5%88%97%E2%80%9C%E7%BB%93%E6%9E%9C%E2%80%9D%E5%8C%85%E5%90%AB%E3%80%82%20%E7%84%B6%E5%90%8E%E4%BD%BF%E7%94%A8%E6%9D%A1%E4%BB%B6%20if%20%E4%BD%BF%E5%85%B6%E6%88%90%E4%B8%BA%E7%9C%9F%E5%AE%9E%E3%80%82%3C%2FP%3E%3CP%3E%2F%2F%20%E5%B0%86%E6%B1%87%E6%80%BB%E6%95%B0%E6%8D%AE%E8%A1%A8%E8%BF%9E%E6%8E%A5%E5%88%B0%E5%8E%9F%E5%A7%8B%E6%95%B0%E6%8D%AE%E8%A1%A8%3C%2FP%3E%3CPRE%3E%3CCODE%20class%3D%22%20language-jsl%22%3EData%20Table(%20%22Data%22%20)%20%26lt%3B%26lt%3B%20Join(%0A%20With(%20Data%20Table(%20%22Data%20By%20(Sensor)%22%20)%20)%2C%0A%20Select(%0A%20%20%3AID%2C%0A%20%20%3ASensor%2C%0A%20%20%3AName(%20%22Sub-Sensor%22%20)%2C%0A%20%20%3AOccurrence%2C%0A%20%20%3ARequired%20Column%2C%0A%20%20%3AName(%20%22Required%20Column%20-Cause%22%20)%0A%20)%2C%0A%20SelectWith(%20%3AResult%20)%2C%0A%20By%20Matching%20Columns(%20%3ASensor%20%3D%20%3ASensor%20)%2C%0A%20Drop%20multiples(%200%2C%200%20)%2C%0A%20Include%20Nonmatches(%200%2C%200%20)%2C%0A%20Preserve%20main%20table%20order(%201%20)%0A)%3B%3C%2FCODE%3E%3C%2FPRE%3E%3CP%3E%2F%2F%20%E5%9C%A8%E2%80%9C%E5%BF%85%E5%A1%AB%E5%88%97-%E5%8E%9F%E5%9B%A0%E2%80%9D%E5%88%97%E4%B8%AD%E6%B7%BB%E5%8A%A0%E5%85%AC%E5%BC%8F%EF%BC%8C%E5%A6%82%E4%B8%8B%E6%89%80%E7%A4%BA%3C%2FP%3E%3CPRE%3E%3CCODE%20class%3D%22%20language-jsl%22%3EIf(%0A%20%3AName(%20%22Sub-Sensor%22%20)%20%3D%3D%20%22Inlet%22%20%26amp%3B%20%3AResult%20%3D%3D%20%22Inlet%22%2C%20%22Inlet%22%2C%0A%20%3AName(%20%22Sub-Sensor%22%20)%20%3D%3D%20%22Return%22%20%26amp%3B%20%3AResult%20%3D%3D%20%22Return%22%2C%20%22Return%22%2C%0A%20%3AName(%20%22Sub-Sensor%22%20)%20%3D%3D%20%22Inlet%22%20%7C%20%3AName(%20%22Sub-Sensor%22%20)%20%3D%3D%20%22Return%22%20%26amp%3B%20%3AResult%20%3D%3D%20%22Both%22%2C%20%22Both%22%2C%0A%20%22%22%0A)%3B%3C%2FCODE%3E%3C%2FPRE%3E%3C%2FLINGO-BODY%3E
Choose Language Hide Translation Bar
HSS
HSS
Level IV

Add one more column based on condition and grouping on other columns

Hello All,
Happy new year, 
I stuck at another place, have idea/logic but not able to put into correct formula. Please see the attached image for description. Sample data is also attached.

HSS_1-1641371240772.png

 

 

Any help?
Many thanks.

1 ACCEPTED SOLUTION

Accepted Solutions
frank_wang
Level IV

Re: Add one more column based on condition and grouping on other columns

Hi HSS

I think there are 3 steps need to do to get your want.

1.  Summarize your data table to map. Index is 'sensor' and Values are 'max(Inlet), max(Reture)'. 

//You can use below JSL to summarzie a new data table

Data Table( "Data" ) << Summary(
	Group( :Sensor ),
	Max( :Occurrence ),
	Subgroup( :Name( "Sub-Sensor" ) ),
	Freq( "None" ),
	Weight( "None" ),
	statistics column name format( "column" )
);

2. Input your conditions by if or match. Here I used If and create a new column in summary data table.

If(
	:Name( "Occurrence, Inlet" ) >= 2 & :Name( "Occurrence, Return" ) >= 2, "Both",
	:Name( "Occurrence, Inlet" ) >= 2 & :Name( "Occurrence, Return" ) < 2, "Inlet",
	:Name( "Occurrence, Inlet" ) < 2 & :Name( "Occurrence, Return" ) >= 2, "Return",
	"Empty"
);

3. Join two data table together by 'Sensor' and make sure column' result ' include. Then use condition if to make it real.

// Join summary data table to original data table

Data Table( "Data" ) << Join(
	With( Data Table( "Data By (Sensor)" ) ),
	Select(
		:ID,
		:Sensor,
		:Name( "Sub-Sensor" ),
		:Occurrence,
		:Required Column,
		:Name( "Required Column -Cause" )
	),
	SelectWith( :Result ),
	By Matching Columns( :Sensor = :Sensor ),
	Drop multiples( 0, 0 ),
	Include Nonmatches( 0, 0 ),
	Preserve main table order( 1 )
);

// add formula in column 'Required Column -Cause' as below

If(
	:Name( "Sub-Sensor" ) == "Inlet" & :Result == "Inlet", "Inlet",
	:Name( "Sub-Sensor" ) == "Return" & :Result == "Return", "Return",
	:Name( "Sub-Sensor" ) == "Inlet" | :Name( "Sub-Sensor" ) == "Return" & :Result == "Both", "Both",
	""
);
心若止水

View solution in original post

2 REPLIES 2
frank_wang
Level IV

Re: Add one more column based on condition and grouping on other columns

Hi HSS

I think there are 3 steps need to do to get your want.

1.  Summarize your data table to map. Index is 'sensor' and Values are 'max(Inlet), max(Reture)'. 

//You can use below JSL to summarzie a new data table

Data Table( "Data" ) << Summary(
	Group( :Sensor ),
	Max( :Occurrence ),
	Subgroup( :Name( "Sub-Sensor" ) ),
	Freq( "None" ),
	Weight( "None" ),
	statistics column name format( "column" )
);

2. Input your conditions by if or match. Here I used If and create a new column in summary data table.

If(
	:Name( "Occurrence, Inlet" ) >= 2 & :Name( "Occurrence, Return" ) >= 2, "Both",
	:Name( "Occurrence, Inlet" ) >= 2 & :Name( "Occurrence, Return" ) < 2, "Inlet",
	:Name( "Occurrence, Inlet" ) < 2 & :Name( "Occurrence, Return" ) >= 2, "Return",
	"Empty"
);

3. Join two data table together by 'Sensor' and make sure column' result ' include. Then use condition if to make it real.

// Join summary data table to original data table

Data Table( "Data" ) << Join(
	With( Data Table( "Data By (Sensor)" ) ),
	Select(
		:ID,
		:Sensor,
		:Name( "Sub-Sensor" ),
		:Occurrence,
		:Required Column,
		:Name( "Required Column -Cause" )
	),
	SelectWith( :Result ),
	By Matching Columns( :Sensor = :Sensor ),
	Drop multiples( 0, 0 ),
	Include Nonmatches( 0, 0 ),
	Preserve main table order( 1 )
);

// add formula in column 'Required Column -Cause' as below

If(
	:Name( "Sub-Sensor" ) == "Inlet" & :Result == "Inlet", "Inlet",
	:Name( "Sub-Sensor" ) == "Return" & :Result == "Return", "Return",
	:Name( "Sub-Sensor" ) == "Inlet" | :Name( "Sub-Sensor" ) == "Return" & :Result == "Both", "Both",
	""
);
心若止水
HSS
HSS
Level IV

Re: Add one more column based on condition and grouping on other columns

Thanks Frank.

It worked.

Recommended Articles