Reputation: 17164
Let's say I have some images in parent directory: ../imagea/a.png and ../images/b.png.
When I do:
ls ../images
# I get
../images/a.png
../images/b.png
How to add the prefix data:image/s3,"s3://crabby-images/d38d1/d38d12bd4bc572e8605d51c0acb8e95f67b8132c" alt=""
for all these outputs?
I tried:
!ls ../images/*.png | cat
# am not sure what to do next
data:image/s3,"s3://crabby-images/b486f/b486f4599ab5dbccc8c42637db26f275d1bc8e37" alt=""
data:image/s3,"s3://crabby-images/59f64/59f6472fab3e5854fecfa688af62505cb7142894" alt=""
Help is appreciated.
Upvotes: 5
Views: 3942
Reputation: 4900
The easiest solution is using the standard posix find
command with printf
action like this:
find ../images -name "*.png" -printf 'data:image/s3,"s3://crabby-images/8517a/8517aea5a28ddf5133bf7daad18b679836ab8167" alt=""\n'
../images
- target directory
"*.png"
- glob pattern
-printf
- format action to output
'data:image/s3,"s3://crabby-images/8517a/8517aea5a28ddf5133bf7daad18b679836ab8167" alt=""\n'
- format arguments to output full path name.
$ ls -l
total 8
drwxrwxr-x. 3 cfrm cfrm 15 Dec 13 2018 app
drwxrwxr-x. 2 cfrm cfrm 23 Mar 24 2019 app_5811_install
drwxrwxr-x. 13 cfrm cfrm 4096 Dec 12 2018 app_58_install
drwxrwxr-x. 2 cfrm cfrm 4096 Oct 3 2018 grants
-rwx------. 1 cfrm cfrm 526 Feb 17 2019 ic_start_all.sh
-rwx------. 1 cfrm cfrm 920 Oct 4 2018 ic_status_all.sh
-rwx------. 1 cfrm cfrm 984 Sep 27 2018 ic_stop_all.sh
-rwxrwxr-x. 1 cfrm cfrm 1693 Dec 13 2018 loadTrigger.sh
$ find . -name "*.sh" -printf 'data:image/s3,"s3://crabby-images/8517a/8517aea5a28ddf5133bf7daad18b679836ab8167" alt=""\n'
data:image/s3,"s3://crabby-images/35c80/35c8077fac70115da10945ab2d53cdc400046ee0" alt=""
data:image/s3,"s3://crabby-images/eace6/eace6e021e7b7b4e59563f4e7452035fd9614d4b" alt=""
data:image/s3,"s3://crabby-images/931e3/931e3f0dbf1836df1fc0e337b94a1b5744c9885c" alt=""
data:image/s3,"s3://crabby-images/a3709/a37094811d1803de09941b9ebee03dffe2549de4" alt=""
Upvotes: 5
Reputation: 38990
First, I disbelieve you. ls ../images
would output only the basenames, like:
a.png
b.png
...etc...
A different command ls ../images/*
could give the output you show.
Although on a system using the ls
from GNU coreutils, like Linux, if the output is a terminal and the filenames are short like you showed, ls
without options would do multicolumn output more like:
../images/aaaaa.png ../images/ddddd.png ../images/ggggg.png
../images/b.png ../images/eeeee.png ../images/hhhhhh.png
../images/ccccc.png ../images/f.png ../images/iiiiii.png
unless you have an alias (or shadowing function or script) that forces the -1
(one) option to prevent this. Or the actual names are (significantly) longer, as they probably should be. Or you are piping to something, even cat
, because then the output of ls
is the pipe not the terminal. These details matter.
For some cases sed is as good as awk, and usually terser:
ls | sed 's/^/data:image/s3,"s3://crabby-images/7ca03/7ca03cbf7ab111f86ba4066ec6f957033356d0c1" alt=""/'
# sed processes a string of command(s) for each line read from stdin,
# and writes the result to stdout (by default, -n overrides this)
# s/old/new/ is string replacement using regex (which can be complex)
# ^ in old matches the beginning of the line
# $ in old matches the end of the line
# this assumes none of your filenames contains a newline character
# which Unix permits, but is rarely done because it is quite confusing
or since you like printf it can do the whole job:
printf 'data:image/s3,"s3://crabby-images/b76b3/b76b36d227576599e9dc057413c75e640db0e9f0" alt=""\n' ../images/*
# printf takes a format string containing any mixture of literal text
# (including backslash+letter escapes mostly the same as C et succ)
# and conversion specifiers beginning with % which each interpolate one argument
# it repeats the format as needed to handle all the arguments, so here
# with one c.s. it repeats the format once for each argument = filename
# this 'works' even if a filename contains newline
# (but I don't think the result will work correctly as markdown)
Upvotes: 3
Reputation: 133650
Could you please try following.
awk 'BEGIN{for(i=1;i<ARGC;i++)print "data:image/s3,"s3://crabby-images/310ce/310ce49a0a573558d5852182f24641af430b121b" alt="""}' ../images/*.png
Output will be as follows(where a,b,c... .png
are test files created by me for testing purposes).
data:image/s3,"s3://crabby-images/6f0af/6f0af84846b9730c0a2c1ba17ff907e36c17ff9d" alt=""
data:image/s3,"s3://crabby-images/14b36/14b3677d5c680255d9e5ccdd6223736f972327c8" alt=""
data:image/s3,"s3://crabby-images/ec4b1/ec4b162f2485214584d405e009b3b4498c5bf42b" alt=""
data:image/s3,"s3://crabby-images/90247/902474ca8c041fcd6755f7af7a8e39e6d541cff0" alt=""
Upvotes: 1
Reputation: 124724
Loop over the glob pattern, and print each line formatted as desired:
for filename in ../*.png; do echo '!'"[]($filename)"; done
Upvotes: 4