awk: add column name with filename in loop2019 Community Moderator Electionchange column with awk scriptingSeparating names separated by “| character” to individual pairsawk change one column with anotherawk Command Loopstat(FILENAME) in awkApplying a mathematical function to every line in a large fileUsing 'awk' to print a placeholder in several blocks of dataPrint column with AWKget average for all numbers with irregular columnsAWK doesn't add new column

GPLv2 - licensing for commercial use

Word for a person who has no opinion about whether god exists

htop displays identical program in multiple lines

Why don't MCU characters ever seem to have language issues?

Good for you! in Russian

Peter's Strange Word

How can I ensure my trip to the UK will not have to be cancelled because of Brexit?

How did the power source of Mar-Vell's aircraft end up with her?

Am I not good enough for you?

Meaning of ちはース

Set and print content of environment variable in cmd.exe subshell?

Word-Letter Ladder

Algorithm to convert a fixed-length string to the smallest possible collision-free representation?

They call me Inspector Morse

Is it necessary to separate DC power cables and data cables?

What are some noteworthy "mic-drop" moments in math?

Grey hair or white hair

Tricky AM-GM inequality

How to clip a background including nodes according to an arbitrary shape?

Why does Deadpool say "You're welcome, Canada," after shooting Ryan Reynolds in the end credits?

How do you like my writing?

Are there historical instances of the capital of a colonising country being temporarily or permanently shifted to one of its colonies?

Replacing Windows 7 security updates with anti-virus?

Why is this plane circling around the LKO airport every day?



awk: add column name with filename in loop



2019 Community Moderator Electionchange column with awk scriptingSeparating names separated by “| character” to individual pairsawk change one column with anotherawk Command Loopstat(FILENAME) in awkApplying a mathematical function to every line in a large fileUsing 'awk' to print a placeholder in several blocks of dataPrint column with AWKget average for all numbers with irregular columnsAWK doesn't add new column










1















I have a question to add a column title during a loop with awk:
I currently have this code, which calculates the mean of each line for each csv file :



for i in *.csv; do 
awk -F"," 'NR==1 next
T=0
for(N=1; N<=NF; N++) T+=$N;
T/=NF
print T ' $i > Mean$i
done


So I get files MeanName1.csv, MeanName2.csv, ... containing:



2.5 3.5 ...
4.2 3.4
1.2 3.9
1.2 3.7


I would like to get a single file "Mean" containing:



Name1 Name2 ...
2.5 3.5
4.2 3.4
1.2 3.9
1.2 3.7


I failed to use print FILENAME in the loop.



Do you have any suggestions ?
Thank you










share|improve this question









New contributor




MLdish is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.




















  • The way you have written the data in the question makes it look like you have several columns of data in the same file. Can we assume that you only have a single column of data per file, as indicated by your actual code?

    – Kusalananda
    1 hour ago











  • Correct, I have only a single column of data in each Mean File.

    – MLdish
    1 hour ago















1















I have a question to add a column title during a loop with awk:
I currently have this code, which calculates the mean of each line for each csv file :



for i in *.csv; do 
awk -F"," 'NR==1 next
T=0
for(N=1; N<=NF; N++) T+=$N;
T/=NF
print T ' $i > Mean$i
done


So I get files MeanName1.csv, MeanName2.csv, ... containing:



2.5 3.5 ...
4.2 3.4
1.2 3.9
1.2 3.7


I would like to get a single file "Mean" containing:



Name1 Name2 ...
2.5 3.5
4.2 3.4
1.2 3.9
1.2 3.7


I failed to use print FILENAME in the loop.



Do you have any suggestions ?
Thank you










share|improve this question









New contributor




MLdish is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.




















  • The way you have written the data in the question makes it look like you have several columns of data in the same file. Can we assume that you only have a single column of data per file, as indicated by your actual code?

    – Kusalananda
    1 hour ago











  • Correct, I have only a single column of data in each Mean File.

    – MLdish
    1 hour ago













1












1








1








I have a question to add a column title during a loop with awk:
I currently have this code, which calculates the mean of each line for each csv file :



for i in *.csv; do 
awk -F"," 'NR==1 next
T=0
for(N=1; N<=NF; N++) T+=$N;
T/=NF
print T ' $i > Mean$i
done


So I get files MeanName1.csv, MeanName2.csv, ... containing:



2.5 3.5 ...
4.2 3.4
1.2 3.9
1.2 3.7


I would like to get a single file "Mean" containing:



Name1 Name2 ...
2.5 3.5
4.2 3.4
1.2 3.9
1.2 3.7


I failed to use print FILENAME in the loop.



Do you have any suggestions ?
Thank you










share|improve this question









New contributor




MLdish is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.












I have a question to add a column title during a loop with awk:
I currently have this code, which calculates the mean of each line for each csv file :



for i in *.csv; do 
awk -F"," 'NR==1 next
T=0
for(N=1; N<=NF; N++) T+=$N;
T/=NF
print T ' $i > Mean$i
done


So I get files MeanName1.csv, MeanName2.csv, ... containing:



2.5 3.5 ...
4.2 3.4
1.2 3.9
1.2 3.7


I would like to get a single file "Mean" containing:



Name1 Name2 ...
2.5 3.5
4.2 3.4
1.2 3.9
1.2 3.7


I failed to use print FILENAME in the loop.



Do you have any suggestions ?
Thank you







awk






share|improve this question









New contributor




MLdish is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.











share|improve this question









New contributor




MLdish is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.









share|improve this question




share|improve this question








edited 2 hours ago







MLdish













New contributor




MLdish is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.









asked 2 hours ago









MLdishMLdish

84




84




New contributor




MLdish is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.





New contributor





MLdish is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.






MLdish is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.












  • The way you have written the data in the question makes it look like you have several columns of data in the same file. Can we assume that you only have a single column of data per file, as indicated by your actual code?

    – Kusalananda
    1 hour ago











  • Correct, I have only a single column of data in each Mean File.

    – MLdish
    1 hour ago

















  • The way you have written the data in the question makes it look like you have several columns of data in the same file. Can we assume that you only have a single column of data per file, as indicated by your actual code?

    – Kusalananda
    1 hour ago











  • Correct, I have only a single column of data in each Mean File.

    – MLdish
    1 hour ago
















The way you have written the data in the question makes it look like you have several columns of data in the same file. Can we assume that you only have a single column of data per file, as indicated by your actual code?

– Kusalananda
1 hour ago





The way you have written the data in the question makes it look like you have several columns of data in the same file. Can we assume that you only have a single column of data per file, as indicated by your actual code?

– Kusalananda
1 hour ago













Correct, I have only a single column of data in each Mean File.

– MLdish
1 hour ago





Correct, I have only a single column of data in each Mean File.

– MLdish
1 hour ago










1 Answer
1






active

oldest

votes


















1














Joining the output files is easiest done with paste, but I don't think it knows how to add the file names as headers. But we can do that manually to the intermediate output files within the loop, so:



for i in *.csv; do
out="Mean$i"
echo "$i%.csv" > "$out"
awk -F"," 'NR==1 next
T=0
for(N=1; N<=NF; N++) T+=$N;
T/=NF
print T ' $i >> "$out"
done
paste Mean*.csv > All.csv


$i%.csv is just the value of $i with the suffix .csv removed, so for foo.csv and bar.csv, that gives an output like this:



bar foo
4.33333 2.5
3.8 3.5



I note you're also skipping the first line of each input line (NR==1 next ). If they contain useful headers, you could of course use those too by changing that to NR==1 print; next and then removing the echo I added above.






share|improve this answer

























  • Exactly what I needed, thanks! (I don't need header of each *.csv files, so I keep echo)

    – MLdish
    1 hour ago











Your Answer








StackExchange.ready(function()
var channelOptions =
tags: "".split(" "),
id: "106"
;
initTagRenderer("".split(" "), "".split(" "), channelOptions);

StackExchange.using("externalEditor", function()
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled)
StackExchange.using("snippets", function()
createEditor();
);

else
createEditor();

);

function createEditor()
StackExchange.prepareEditor(
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: false,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: null,
bindNavPrevention: true,
postfix: "",
imageUploader:
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
,
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
);



);






MLdish is a new contributor. Be nice, and check out our Code of Conduct.









draft saved

draft discarded


















StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2funix.stackexchange.com%2fquestions%2f505910%2fawk-add-column-name-with-filename-in-loop%23new-answer', 'question_page');

);

Post as a guest















Required, but never shown

























1 Answer
1






active

oldest

votes








1 Answer
1






active

oldest

votes









active

oldest

votes






active

oldest

votes









1














Joining the output files is easiest done with paste, but I don't think it knows how to add the file names as headers. But we can do that manually to the intermediate output files within the loop, so:



for i in *.csv; do
out="Mean$i"
echo "$i%.csv" > "$out"
awk -F"," 'NR==1 next
T=0
for(N=1; N<=NF; N++) T+=$N;
T/=NF
print T ' $i >> "$out"
done
paste Mean*.csv > All.csv


$i%.csv is just the value of $i with the suffix .csv removed, so for foo.csv and bar.csv, that gives an output like this:



bar foo
4.33333 2.5
3.8 3.5



I note you're also skipping the first line of each input line (NR==1 next ). If they contain useful headers, you could of course use those too by changing that to NR==1 print; next and then removing the echo I added above.






share|improve this answer

























  • Exactly what I needed, thanks! (I don't need header of each *.csv files, so I keep echo)

    – MLdish
    1 hour ago
















1














Joining the output files is easiest done with paste, but I don't think it knows how to add the file names as headers. But we can do that manually to the intermediate output files within the loop, so:



for i in *.csv; do
out="Mean$i"
echo "$i%.csv" > "$out"
awk -F"," 'NR==1 next
T=0
for(N=1; N<=NF; N++) T+=$N;
T/=NF
print T ' $i >> "$out"
done
paste Mean*.csv > All.csv


$i%.csv is just the value of $i with the suffix .csv removed, so for foo.csv and bar.csv, that gives an output like this:



bar foo
4.33333 2.5
3.8 3.5



I note you're also skipping the first line of each input line (NR==1 next ). If they contain useful headers, you could of course use those too by changing that to NR==1 print; next and then removing the echo I added above.






share|improve this answer

























  • Exactly what I needed, thanks! (I don't need header of each *.csv files, so I keep echo)

    – MLdish
    1 hour ago














1












1








1







Joining the output files is easiest done with paste, but I don't think it knows how to add the file names as headers. But we can do that manually to the intermediate output files within the loop, so:



for i in *.csv; do
out="Mean$i"
echo "$i%.csv" > "$out"
awk -F"," 'NR==1 next
T=0
for(N=1; N<=NF; N++) T+=$N;
T/=NF
print T ' $i >> "$out"
done
paste Mean*.csv > All.csv


$i%.csv is just the value of $i with the suffix .csv removed, so for foo.csv and bar.csv, that gives an output like this:



bar foo
4.33333 2.5
3.8 3.5



I note you're also skipping the first line of each input line (NR==1 next ). If they contain useful headers, you could of course use those too by changing that to NR==1 print; next and then removing the echo I added above.






share|improve this answer















Joining the output files is easiest done with paste, but I don't think it knows how to add the file names as headers. But we can do that manually to the intermediate output files within the loop, so:



for i in *.csv; do
out="Mean$i"
echo "$i%.csv" > "$out"
awk -F"," 'NR==1 next
T=0
for(N=1; N<=NF; N++) T+=$N;
T/=NF
print T ' $i >> "$out"
done
paste Mean*.csv > All.csv


$i%.csv is just the value of $i with the suffix .csv removed, so for foo.csv and bar.csv, that gives an output like this:



bar foo
4.33333 2.5
3.8 3.5



I note you're also skipping the first line of each input line (NR==1 next ). If they contain useful headers, you could of course use those too by changing that to NR==1 print; next and then removing the echo I added above.







share|improve this answer














share|improve this answer



share|improve this answer








edited 1 hour ago

























answered 1 hour ago









ilkkachuilkkachu

61k1098174




61k1098174












  • Exactly what I needed, thanks! (I don't need header of each *.csv files, so I keep echo)

    – MLdish
    1 hour ago


















  • Exactly what I needed, thanks! (I don't need header of each *.csv files, so I keep echo)

    – MLdish
    1 hour ago

















Exactly what I needed, thanks! (I don't need header of each *.csv files, so I keep echo)

– MLdish
1 hour ago






Exactly what I needed, thanks! (I don't need header of each *.csv files, so I keep echo)

– MLdish
1 hour ago











MLdish is a new contributor. Be nice, and check out our Code of Conduct.









draft saved

draft discarded


















MLdish is a new contributor. Be nice, and check out our Code of Conduct.












MLdish is a new contributor. Be nice, and check out our Code of Conduct.











MLdish is a new contributor. Be nice, and check out our Code of Conduct.














Thanks for contributing an answer to Unix & Linux Stack Exchange!


  • Please be sure to answer the question. Provide details and share your research!

But avoid


  • Asking for help, clarification, or responding to other answers.

  • Making statements based on opinion; back them up with references or personal experience.

To learn more, see our tips on writing great answers.




draft saved


draft discarded














StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2funix.stackexchange.com%2fquestions%2f505910%2fawk-add-column-name-with-filename-in-loop%23new-answer', 'question_page');

);

Post as a guest















Required, but never shown





















































Required, but never shown














Required, but never shown












Required, but never shown







Required, but never shown

































Required, but never shown














Required, but never shown












Required, but never shown







Required, but never shown







-awk

Popular posts from this blog

Mobil Contents History Mobil brands Former Mobil brands Lukoil transaction Mobil UK Mobil Australia Mobil New Zealand Mobil Greece Mobil in Japan Mobil in Canada Mobil Egypt See also References External links Navigation menuwww.mobil.com"Mobil Corporation"the original"Our Houston campus""Business & Finance: Socony-Vacuum Corp.""Popular Mechanics""Lubrite Technologies""Exxon Mobil campus 'clearly happening'""Toledo Blade - Google News Archive Search""The Lion and the Moose - How 2 Executives Pulled off the Biggest Merger Ever""ExxonMobil Press Release""Lubricants""Archived copy"the original"Mobil 1™ and Mobil Super™ motor oil and synthetic motor oil - Mobil™ Motor Oils""Mobil Delvac""Mobil Industrial website""The State of Competition in Gasoline Marketing: The Effects of Refiner Operations at Retail""Mobil Travel Guide to become Forbes Travel Guide""Hotel Rankings: Forbes Merges with Mobil"the original"Jamieson oil industry history""Mobil news""Caltex pumps for control""Watchdog blocks Caltex bid""Exxon Mobil sells service station network""Mobil Oil New Zealand Limited is New Zealand's oldest oil company, with predecessor companies having first established a presence in the country in 1896""ExxonMobil subsidiaries have a business history in New Zealand stretching back more than 120 years. We are involved in petroleum refining and distribution and the marketing of fuels, lubricants and chemical products""Archived copy"the original"Exxon Mobil to Sell Its Japanese Arm for $3.9 Billion""Gas station merger will end Esso and Mobil's long run in Japan""Esso moves to affiliate itself with PC Optimum, no longer Aeroplan, in loyalty point switch""Mobil brand of gas stations to launch in Canada after deal for 213 Loblaws-owned locations""Mobil Nears Completion of Rebranding 200 Loblaw Gas Stations""Learn about ExxonMobil's operations in Egypt""Petrol and Diesel Service Stations in Egypt - Mobil"Official websiteExxon Mobil corporate websiteMobil Industrial official websiteeeeeeeeDA04275022275790-40000 0001 0860 5061n82045453134887257134887257

Frič See also Navigation menuinternal link

Identify plant with long narrow paired leaves and reddish stems Planned maintenance scheduled April 17/18, 2019 at 00:00UTC (8:00pm US/Eastern) Announcing the arrival of Valued Associate #679: Cesar Manara Unicorn Meta Zoo #1: Why another podcast?What is this plant with long sharp leaves? Is it a weed?What is this 3ft high, stalky plant, with mid sized narrow leaves?What is this young shrub with opposite ovate, crenate leaves and reddish stems?What is this plant with large broad serrated leaves?Identify this upright branching weed with long leaves and reddish stemsPlease help me identify this bulbous plant with long, broad leaves and white flowersWhat is this small annual with narrow gray/green leaves and rust colored daisy-type flowers?What is this chilli plant?Does anyone know what type of chilli plant this is?Help identify this plant