× The internal search function is temporarily non-functional. The current search engine is no longer viable and we are researching alternatives.
As a stop gap measure, we are using Google's custom search engine service.
If you know of an easy to use, open source, search engine ... please contact support@midrange.com.



Kevin, I think the OP meant something a bit different from your specification here - here's my understanding -

blanks are placeholders and you need a single comma for each blank variable

This is very easily handled with a procedure (several have suggested using a procedure), maybe even the one I posted earlier, which returns either the passed value when not blank or a single comma when blank.

Regards
Vern

On 1/15/2020 7:50 AM, Kevin Bucknum wrote:
If as Vernon says blanks are placeholders and you just need a single comma for all blank spaces, then the concat and regex looks like this.

WorkVar = V1 + ' '
+ V2 + ' '
+ V3 + ' '
+ V4 + ' '
+ V5 + ' '
+ V6;

Exec Sql Select
Regexp_Replace(
:WorkVar,
'\s+',',',1,0,'c')
Into :NewVar
From sysibm.sysdummy1;

On Tue, 2020-01-14 at 20:40 +0000, Kevin Bucknum wrote:

Just because I've been in regex hell all morning on another project I decided to see how ugly it would be. If you have unicode installed, this works.

**Free

Dcl-s V1 Char(5);

Dcl-s V2 Char(5);

Dcl-s V3 Char(5);

Dcl-s V4 Char(5);

Dcl-s V5 Char(5);

Dcl-s V6 Char(5);

Dcl-S NewVar Char(35

);

Dcl-S WorkVar Char(35);


V1 = *Blanks;

V2 = '0.022';

V3 = *Blanks;

V4 = *Blanks;

V5 = '0.022';

V6 = *Blanks;


WorkVar = %Trim(V1) + ','

+ %Trim(V2) + ','

+ %Trim(V3) + ','

+ %Trim(V4) + ','

+ %Trim(V5) + ','

+ %Trim(V6);


Exec Sql Select Regexp_Replace(

Regexp_Replace(

Trim(:WorkVar),

',{3,}',',,',1,0,'c'),

'^,{2}|,{2}$',',',1,0,'c')

Into :NewVar

From sysibm.sysdummy1;


Dsply WorkVar;

Dsply NewVar;

*Inlr = *On;

Return;




[https://www.medtronsoftware.com/img/MedtronMinilogo.bmp] Kevin Bucknum
Senior Programmer Analyst
MEDDATA / MEDTRON
120 Innwood Drive
Covington LA 70433
Local: 985-893-2550
Toll Free: 877-893-2550
https://www.medtronsoftware.com



CONFIDENTIALITY NOTICE

This document and any accompanying this email transmission contain confidential information, belonging to the sender that is legally privileged. This information is intended only for the use of the individual or entity named above. The authorized recipient of this information is prohibited from disclosing this information to any other party and is required to destroy the information after its stated need has been fulfilled. If you are not the intended recipient, or the employee of agent responsible to deliver it to the intended recipient, you are hereby notified that any disclosure, copying, distribution or action taken in reliance on the contents of these documents is STRICTLY PROHIBITED. If you have received this email in error, please notify the sender immediately to arrange for return or destruction of these documents.


As an Amazon Associate we earn from qualifying purchases.

This thread ...

Replies:

Follow On AppleNews
Return to Archive home page | Return to MIDRANGE.COM home page

This mailing list archive is Copyright 1997-2024 by midrange.com and David Gibbs as a compilation work. Use of the archive is restricted to research of a business or technical nature. Any other uses are prohibited. Full details are available on our policy page. If you have questions about this, please contact [javascript protected email address].

Operating expenses for this site are earned using the Amazon Associate program and Google Adsense.