1

I have a python function which takes a parameter as input and I want to automate and call it through bash. But bash is giving error when i pass variable(string) when calling it

a="test"
python -c "from pipeline_runs.z_full_pipeline import test; test($a)"

fails with

NameError: name 'test' is not defined

But the same runs when variable is int

a="10"
python -c "from pipeline_runs.z_full_pipeline import test; test($a)"

This runs while the first code fails. Can anyone explain why the behavior is so, and what should I change to pass string from bash script to python function

12
  • This question is really "how do I pass strings to a python program" (and it's not done the way you do it), and it's honestly a programming question. To make this really short: you want to use command line arguments, or passing in textual data through standard input. Both is well-documented for Python! Commented Apr 14, 2023 at 15:35
  • 1
    People: Please don't vote to migrate on topic questions. This is 100% on topic here and should not be migrated. Commented Apr 14, 2023 at 15:53
  • 1
    @MarcusMüller python is a standard tool used to administer *nix systems and this is not a question about string literals, it's about "how do I get my *nix system to work with this" and that is on topic. Commented Apr 14, 2023 at 15:59
  • 1
    @MarcusMüller the main issue here is about the shell, python is incidental. The reason it doesn't work is because the variable is expanded by the shell before python ever sees it, so python ends up seeing an unquoted string literal. So it really is about how the shell and python interact. If this had been presented as a python script, that could arguably be off topic, but a one-liner is essentially a *nix command, so... Commented Apr 14, 2023 at 16:05
  • 1
    Oh, and to clarify, I have no more "authority" about what is on topic than anyone else. Mods don't decide that, the community does. Mods do tend to be very familiar with the scope, that much is true, but that doesn't mean I'm right just because I'm a mod! Commented Apr 14, 2023 at 16:06

2 Answers 2

5

Make it a shell function instead. Paste this into your terminal, or add to your shell's configuration files (e.g. ~/.bashrc for bash)

pipeline_test(){
  python -c 'from sys import argv; from pipeline_runs.z_full_pipeline import test; test(argv[1])' "$@"
}

And then run as

pipeline_test "$a"
2
  • Thanks, this works too Commented Apr 14, 2023 at 16:01
  • In my humble opinion, this is the better method: while passing as environment variable like Frédéric does works, it's a bit strange to do it, when argument passing was literally invented to, and named after, passing string arguments to programs. It also has no side effects to processes spawned further down the line, so from a cleanliness aspect, I'd prefer this argument passing here to the environment-modification in Frédéric's answer :) Commented Apr 14, 2023 at 16:13
-1

Just try:

export a="test"
python -c "from pipeline_runs.z_full_pipeline import test; test('$a')"

In this case, the command will be expanded to from pipeline_runs.z_full_pipeline import test; test('test')

And you will have 'test' instead of test. The former is a string and the later is an undefined variable.

But a safe way to proceed is to use the os.environ dictionary. Then you put a script in a example.py file. And start with:

import os
a = os.environ['a']
test(a)

This way is better scalable and you don't have to expand a string.

Note, in shell, a="test" and a=test are synonymous.

5
  • Thanks, the above one works but below one, using os module gives KeyError Commented Apr 14, 2023 at 16:00
  • Note that you need to export a for it to be available in os.environ. Commented Apr 14, 2023 at 16:00
  • I have forgotten to tell you to export the variable. export a=test. Commented Apr 14, 2023 at 16:01
  • Ah, that makes it work. Thank you Commented Apr 14, 2023 at 16:02
  • 1
    The first one would be an example of what not to do. Use os.environ or sys.argv, but don't embed the expansion of the variable in the code argument. That's a typical ACE vulnerability. Commented Apr 14, 2023 at 18:10

You must log in to answer this question.

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.