You may refer to $1 inside a function, no problems. But, remember that in awk, all the variables used in a user-defined function are global (except for those passed as parameters while invoking the function). So, if your function changes $1 in any way (assignment,sub/gsub,etc.), those changes will be permanent, which might not be what you wanted.
So, it's always better to pass data to functions using the parameters so that you are working on a copy of the data and in no way, changing/destroying with the original data.
This User Gave Thanks to elixir_sinari For This Post:
However, I am a bit confused with "values" and "parameters".
if I take the example of the code I' ve written in the previous post (same as at the end here).
"w" is the parameter defining the value "$1".
Quote:
So, it's always better to pass data to functions using the parameters so that you are working on a copy of the data and in no way, changing/destroying with the original data.
How do you pass data to functions using parameters?
Do you need to assign the parameter ("w") to the value ("$1") before invoking the function? Tell me if I am wrong, but with the code below it would give:
Quote:
(except for those passed as parameters while invoking the function)
That's what I did before, but $1 is not recognised once I invoked the function. ???
I don't get it. What is the difference between the field value (e.g. $1) and the content of the field? Is it not the same at the end?
You are right, the contents of the field, and field value are the same. What I was suggesting was passing the value to the function rather than using $1 inside of the function. It's not always possible/easy to avoid using globals, but when you can avoid them it is best.
To pass $1 to a function you just put $1 in the call to the function. It is assigned to the variable in the matching position in the function definition. For instance, the function foo accepts two parameters:
and if you want to add fields 1 and 2 from the input record to be processed by foo(), then you can call it like this:
When the function is invoked, the contents of field1 is assigned to p1 and the contents of field 2 is assigned to p2.
Quote:
I managed to go farther with your code and added a for loop after to increment the start position:
it returns:
However, if I want farther to extend the code and refer to this field, for example to print only string without X (as a beginning), is there any way to use again the term "$1" in the rest of the script?
Even when I re-assign the value to $1 it doesn't work!
[code]
Yes, as long as you don't assign anything to $1, you can use it later in the script.
But, how could I do if I would need a track of the output I got after converting number to letters, but need to keep going in my script using this ouptut (the track I produced just before) as an input for the rest of the script.
I know how to output from the script, but I don't know how to input a new file from the script.
Is it doable with awk?
I tried several variants of that but it didn't work: ---------- Post updated 21-09-12 at 08:29 PM ---------- Previous update was 20-09-12 at 09:24 PM ----------
But, how could I do if I would need a track of the output I got after converting number to letters, but need to keep going in my script using this ouptut (the track I produced just before) as an input for the rest of the script.
I know how to output from the script, but I don't know how to input a new file from the script.
Is it doable with awk?
It depends on what you need. Your example is a bit confusing to me. Remember that awk processes the input file one line at a time. Your example was trying to read the track.text file before it was closed (you weren't finished writing to it).
You have a choice depending on what you need to do. You can make the translation and save it in a variable, and use that variable in the rest of your script, or you can create the file track.text and then use a second script to process its contents. You've not stated what you are trying to do, and that might help provide you with a more specific answer to your question.
If it's possible to give an example of your input and desired output that'd be great. At the moment I'm not able to check very often, but there are lots of others on this site that can provide good direction.
I need to convert every second line of the input starting from the first letter, then starting from the second letter, then the third, ..., and finally starting from the letter before the last one (according to the conversion table in the BEGIN section).
input:
in order to get this ouput:
I wanted to do that with 2 different approaches, just to be familiar with awk user-defined function and the function getline:
1) using an increment in a function called "convert(letter)" with only one argument, and use the result as a variable that I could use in the rest of the script. This is the topic I posted in a different thread:https://www.unix.com/unix-dummies-que...program-2.html
2) not using an increment in the function called "convert(letter, start)" with two arguments (the string to convert + the position to start), and redirect the results from the script to an output file. From this file I wanted to use the getline function to redirect it from the script and keep processing it. This is the topic of this thread.
But it appeared that none of these strategies work !!!
For the purpose of this thread I focused on using getline function (2nd strategy).
I tried:
The output I obtain with this code is messy (a mix between the original input with no FS, RS...)
Last edited by beca123456; 09-22-2012 at 10:18 PM..
logs:
"/home/abc/public_html/index.php"
"/home/abc/public_html/index.php"
"/home/xyz/public_html/index.php"
"/home/xyz/public_html/index.php"
"/home/xyz/public_html/index.php"
how to use "cut" or "awk" or "sed" to get the following result:
abc
abc
xyz
xyz
xyz (8 Replies)
HP rp5450 (L2000)
running HP-UX 11.11B
Using DLT 7000 and DLT 4000 tape drives for nightly full backups
Backup jobs created by SAM
DLT 7000 cron entry is as follows:
00 2 * * 1-6 /usr/sam/lbin/br_backup DLT FULL Y /dev/rmt/0m /var/sam/graphLCAa17036 root Y 1 N > /var/sam/SAM_br_msgs 2>&1... (1 Reply)
Hi,
I have line in input file as below:
3G_CENTRAL;INDONESIA_(M)_TELKOMSEL;SPECIAL_WORLD_GRP_7_FA_2_TELKOMSEL
My expected output for line in the file must be :
"1-Radon1-cMOC_deg"|"LDIndex"|"3G_CENTRAL|INDONESIA_(M)_TELKOMSEL"|LAST|"SPECIAL_WORLD_GRP_7_FA_2_TELKOMSEL"
Can someone... (7 Replies)
Hello,
I am working on solving an NP-Complete problem, so it is very important that operations and data with limited integer-argument ranges be computed using immutable look-up-tables contained entirely in CPU cache. Retrieval of the look-up-table data must never leave the CPU once initially... (6 Replies)
I have files that store multiple data points for the same device "vertically" and include multiple devices. It repeats a consistant pattern of lines where for each line:
Column 1 is a common number for the entire file and all devices in that file
Column 2 is a unique device number
Column 3 is... (7 Replies)
I was writing a awk function and had a error I was wondering about. It revolves around a Multidimensional array starting with ord
example:
if ( _e == 5 ) {
lmrb=$5 ; lmtb=$6 ; larb=$7 ;
latb=$8
}
... (2 Replies)
I am attempting to write a awk script that reads in a file after awk array elements are assigned and using those elements while reading in the new file. Does this make sense?
/pattern/ {tst=$3}
(( getline < "file" ) > 0 ) {
x=x " "tst
}
When I print tst in the END statement it... (9 Replies)
Hi Friends,
Can any of you explain me about the below line of code?
mn_code=`env|grep "..mn"|awk -F"=" '{print $2}'`
Im not able to understand, what exactly it is doing :confused:
Any help would be useful for me.
Lokesha (4 Replies)