Warum wird "(base)" vor der Eingabeaufforderung meines Terminals angezeigt?

87

Laut Titel frage ich mich, warum ich (base)auf der linken Seite meiner Terminal-Eingabeaufforderung habe.

Wenn ich source ~/.profileim Terminal laufe , verschwindet es.

Wenn ich das Terminal schließe und ein neues Terminal öffne, (base)ist es wieder da.

Ich würde gerne wissen, was es ist, danke.

Schauen Sie sich das Bild an:

Bild meiner Aufforderung

Hier ist der Inhalt von meinem .profile(ohne Standard $ Pfad Zeug und andere personalisierte Dinge):

# if running bash
if [ -n "$BASH_VERSION" ]; then
    # include .bashrc if it exists
    if [ -f "$HOME/.bashrc" ]; then
        . "$HOME/.bashrc"
    fi
fi

Hier ist der Inhalt meiner .bashrc

# If not running interactively, don't do anything
case $- in
    *i*) ;;
      *) return;;
esac

# don't put duplicate lines or lines starting with space in the history.
# See bash(1) for more options
HISTCONTROL=ignoreboth

# append to the history file, don't overwrite it
shopt -s histappend

# for setting history length see HISTSIZE and HISTFILESIZE in bash(1)
HISTSIZE=1000
HISTFILESIZE=2000

# check the window size after each command and, if necessary,
# update the values of LINES and COLUMNS.
shopt -s checkwinsize

# If set, the pattern "**" used in a pathname expansion context will
# match all files and zero or more directories and subdirectories.
#shopt -s globstar

# make less more friendly for non-text input files, see lesspipe(1)
[ -x /usr/bin/lesspipe ] && eval "$(SHELL=/bin/sh lesspipe)"

# set variable identifying the chroot you work in (used in the prompt below)
if [ -z "${debian_chroot:-}" ] && [ -r /etc/debian_chroot ]; then
    debian_chroot=$(cat /etc/debian_chroot)
fi

# set a fancy prompt (non-color, unless we know we "want" color)
case "$TERM" in
    xterm-color|*-256color) color_prompt=yes;;
esac

# uncomment for a colored prompt, if the terminal has the capability; turned
# off by default to not distract the user: the focus in a terminal window
# should be on the output of commands, not on the prompt
#force_color_prompt=yes

if [ -n "$force_color_prompt" ]; then
    if [ -x /usr/bin/tput ] && tput setaf 1 >&/dev/null; then
    # We have color support; assume it's compliant with Ecma-48
    # (ISO/IEC-6429). (Lack of such support is extremely rare, and such
    # a case would tend to support setf rather than setaf.)
    color_prompt=yes
    else
    color_prompt=
    fi
fi

if [ "$color_prompt" = yes ]; then
    PS1='${debian_chroot:+($debian_chroot)}\[\033[01;32m\]\u@\h\[\033[00m\]:\[\033[01;34m\]\w\[\033[00m\]\$ '
else
    PS1='${debian_chroot:+($debian_chroot)}\u@\h:\w\$ '
fi
unset color_prompt force_color_prompt

# If this is an xterm set the title to user@host:dir
case "$TERM" in
xterm*|rxvt*)
    PS1="\[\e]0;${debian_chroot:+($debian_chroot)}\u@\h: \w\a\]$PS1"
    ;;
*)
    ;;
esac

# enable color support of ls and also add handy aliases
if [ -x /usr/bin/dircolors ]; then
    test -r ~/.dircolors && eval "$(dircolors -b ~/.dircolors)" || eval "$(dircolors -b)"
    alias ls='ls --color=auto'
    #alias dir='dir --color=auto'
    #alias vdir='vdir --color=auto'

    alias grep='grep --color=auto'
    alias fgrep='fgrep --color=auto'
    alias egrep='egrep --color=auto'
fi

# colored GCC warnings and errors
#export GCC_COLORS='error=01;31:warning=01;35:note=01;36:caret=01;32:locus=01:quote=01'

# some more ls aliases
alias ll='ls -alF'
alias la='ls -A'
alias l='ls -CF'

# Add an "alert" alias for long running commands.  Use like so:
#   sleep 10; alert
alias alert='notify-send --urgency=low -i "$([ $? = 0 ] && echo terminal || echo error)" "$(history|tail -n1|sed -e '\''s/^\s*[0-9]\+\s*//;s/[;&|]\s*alert$//'\'')"'

# Alias definitions.
# You may want to put all your additions into a separate file like
# ~/.bash_aliases, instead of adding them here directly.
# See /usr/share/doc/bash-doc/examples in the bash-doc package.

if [ -f ~/.bash_aliases ]; then
    . ~/.bash_aliases
fi

# enable programmable completion features (you don't need to enable
# this, if it's already enabled in /etc/bash.bashrc and /etc/profile
# sources /etc/bash.bashrc).
if ! shopt -oq posix; then
  if [ -f /usr/share/bash-completion/bash_completion ]; then
    . /usr/share/bash-completion/bash_completion
  elif [ -f /etc/bash_completion ]; then
    . /etc/bash_completion
  fi
fi

# added by Anaconda3 installer
#export PATH="/home/jim/anaconda3/bin:$PATH"
. /home/jim/anaconda3/etc/profile.d/conda.sh
conda activate

Ich habe überall gesucht, aber keine Antwort gefunden. Ein anderer Benutzer hat die gleichen Fragen gestellt, die jedoch noch nicht beantwortet wurden:

Jimmy
quelle

Antworten:

37

Dies scheint aus Ihrer condaUmgebung zu kommen . Insbesondere aktivieren Sie condavon Ihrem ~/.bashrcwie folgt

# added by Anaconda3 installer
#export PATH="/home/jim/anaconda3/bin:$PATH"
. /home/jim/anaconda3/etc/profile.d/conda.sh
conda activate

und conda activatestellt Ihrer Eingabeaufforderung Folgendes voran: (<env-name->)-, da Sie keine bestimmte Umgebung angeben , die standardmäßig verwendet wird (base).

Das Verhalten ist unter Verwenden der Conda-Konfigurationsdatei ".condarc" dokumentiert :

Eingabeaufforderung ändern (changeps1)

Ändern Sie bei Verwendung von activate die Eingabeaufforderung von $ PS1, um die aktivierte Umgebung einzuschließen. Der Standardwert ist True.

BEISPIEL:

changeps1: False

Um dies zu .condarcvermeiden , müssen Sie entweder Ihre Datei suchen und ändern oder conda nicht aus Ihrer ~/.bashrcDatei aktivieren .

Stahlfahrer
quelle
101

Dies kann auch daran auto_activate_baseliegen, dass True festgelegt ist. Sie können dies mit dem folgenden Befehl überprüfen

conda config --show | grep auto_activate_base

Falsch setzen

conda config --set auto_activate_base False
bksahu
quelle
5
Dieser Befehl hat mir endlich geholfen! Die anderen Lösungen haben nicht funktioniert, da my changeps1bereits auf false gesetzt war. Der Fehler in meinem Fall ist nach der Installation matplotlibüber aufgetreten conda. Vorher (base)würde sich das nie zeigen. Danke, dass du die Zeile hinzugefügt hast, um die Konfiguration zu überprüfen!
Andrusch
Endlich trifft jemand das Ziel. Aber wissen Sie, warum dieser Wert plötzlich auf True umgeschaltet wird? (In meinem Fall war es für eine lange Zeit nicht so)
HongboZhu
1
PS: Das Terminal muss geschlossen und erneut geöffnet werden, damit die Änderung wirksam wird
Nino Filiu,
Dies scheint auch für mich funktioniert zu haben. Mein Ziel war es jedoch nur, die (base)Zeichen von der Eingabeaufforderung zu entfernen . Ich möchte mein conda / python / jupyter / etc-Setup nicht ändern. > Wird dies nur entfernen , (base)ohne irgendwelche Nebenwirkungen aus der Aufforderung? Wenn nicht, was könnten die Nebenwirkungen sein?
TransferOrbit
Danke für die Lösung. Es hat bei mir funktioniert.
Suraj Dubey
24

(base) erscheint aufgrund von Änderungen in der Conda-Umgebung.

Der folgende Befehl verbirgt die (Basis-) Umgebung.

conda config --set changeps1 False
Felix Solomon
quelle
1
Um es nur für die Basisumgebung,
Homero Esmeraldo,
3

Geben Sie Folgendes ein, um eine Conda-Umgebung zu deaktivieren:

conda deactivate

Dadurch wird die (base)Eingabeaufforderung vor Ihrer Linux-Installation entfernt, wie hier gezeigt:

(Basis) Benutzer @ Büro-PC: ~ $

Marley Davis
quelle
-1

lief der Code unten dann eingegeben conda deactivateund die Basis ging weg.

echo >&2 "DeprecationWarning: 'source deactivate' is deprecated. Use 'conda deactivate'."
"$_CONDA_ROOT/etc/profile.d/conda.sh" || return $?

conda deaktivieren

Steven Peterson
quelle
-1

Es scheint immer noch ein experimentelles Merkmal von Anaconda zu sein.

Um es wieder normal zu machen, können Sie den Befehl ausführen:

conda init --reverse

Dann müssen Sie das aktuelle Shell-Fenster schließen und ein neues öffnen, um die Änderungen zu sehen.

Anderson Chaves
quelle