substr-awk problem

Hi,
I am not a unix specialist but I need a script to resolve my problem. I know the algorithm but I don’t know to write this using awk in my script.
I want to have something like this:

If substr($6, length($6-1) =”_” then
TBL=$6$REG_TBL
Else
TBL=substr($6,1,18)$REG_TBL”_DM”
endif

Can somebody help my, please?
Thanks in advance
P.S.  I take $6 from rfsh.env file
ersatzAsked:
Who is Participating?
I wear a lot of hats...

"The solutions and answers provided on Experts Exchange have been extremely helpful to me over the last few years. I wear a lot of hats - Developer, Database Administrator, Help Desk, etc., so I know a lot of things but not a lot about one thing. Experts Exchange gives me answers from people who do know a lot about one thing, in a easy to use platform." -Todd S.

shivsaCommented:
could u post a simple example with all the values fill in.
ii can not understand the question.
0
ahoffmannCommented:
> substr($6, length($6-1)
returns a string >= 0 characters
did you probably mean
  substr($6,length($6))

Then it's something like this:

{ REG_TBL_DM='irgendein ersatz'; REG_TBL='ersetzen';
  if (substr($6,length($6)) == "_"){
     TBL=$6REG_TBL
  } else {
    TBL=substr($6,1,18)$REG_TBL_DM
  }
0
HamdyHassanCommented:

I think he means ..................

if last char of $6 is "_"  then  table name will be $6$REG_TBL
otherwise It will be "first 18 char of $6" + $REG_TBL + "_DM"





0
Cloud Class® Course: Microsoft Office 2010

This course will introduce you to the interfaces and features of Microsoft Office 2010 Word, Excel, PowerPoint, Outlook, and Access. You will learn about the features that are shared between all products in the Office suite, as well as the new features that are product specific.

ersatzAuthor Commented:
Hi,
You have right,I made a mistake.
My 6th column contains a variable string.
Example of this field value: F4REP_ACCOUNT_OUT_
or                            F4REP_ACCOUNT_OUT_ _DM.
REG_TBL=MMFSA
If substr($6, length($6-1), 1) =”_” then
TBL=$6$REG_TBL                      ($6 concatenate with $REG_TBL)
Else
TBL=substr($6,1,18)$REG_TBL”_DM”   (substr($6,1,18) concatenate with $REG_TBL concatenate with  "_DM"
endif
I am waiting for your answer.
Thanks again
0
shivsaCommented:
#!/bin/ksh
set +x

six=F4REP_ACCOUNT_OUT_
REG_TBL=MMFSA
REG_TBL_DM=MMFSA_DM

TBL=`echo "$six $REG_TBL" | awk '{
     if (substr($1,length($1)) == "_"){
     print $1 $2;
} else {
     print substr($1,1,18) $2 "_DM";
}
}'`
echo $TBL
0

Experts Exchange Solution brought to you by

Your issues matter to us.

Facing a tech roadblock? Get the help and guidance you need from experienced professionals who care. Ask your question anytime, anywhere, with no hassle.

Start your 7-day free trial
ahoffmannCommented:
if the answer was just worth a B grading, what is more worth than mine?
0
It's more than this solution.Get answers and train to solve all your tech problems - anytime, anywhere.Try it for free Edge Out The Competitionfor your dream job with proven skills and certifications.Get started today Stand Outas the employee with proven skills.Start learning today for free Move Your Career Forwardwith certification training in the latest technologies.Start your trial today
System Programming

From novice to tech pro — start learning today.

Question has a verified solution.

Are you are experiencing a similar issue? Get a personalized answer when you ask a related question.

Have a better answer? Share it in a comment.