2021-06-12 09:50:29 +08:00
|
|
|
# python command
|
|
|
|
alias py='python'
|
|
|
|
|
2011-04-13 22:55:24 +08:00
|
|
|
# Find python file
|
|
|
|
alias pyfind='find . -name "*.py"'
|
|
|
|
|
2019-10-25 19:24:35 +08:00
|
|
|
# Remove python compiled byte-code and mypy/pytest cache in either the current
|
|
|
|
# directory or in a list of specified directories (including sub directories).
|
2012-10-27 00:38:17 +08:00
|
|
|
function pyclean() {
|
|
|
|
ZSH_PYCLEAN_PLACES=${*:-'.'}
|
|
|
|
find ${ZSH_PYCLEAN_PLACES} -type f -name "*.py[co]" -delete
|
2013-11-13 08:55:28 +08:00
|
|
|
find ${ZSH_PYCLEAN_PLACES} -type d -name "__pycache__" -delete
|
2019-10-25 19:24:35 +08:00
|
|
|
find ${ZSH_PYCLEAN_PLACES} -depth -type d -name ".mypy_cache" -exec rm -r "{}" +
|
|
|
|
find ${ZSH_PYCLEAN_PLACES} -depth -type d -name ".pytest_cache" -exec rm -r "{}" +
|
2012-10-27 00:38:17 +08:00
|
|
|
}
|
2012-03-22 05:34:19 +08:00
|
|
|
|
2020-03-02 20:38:44 +08:00
|
|
|
# Add the user installed site-packages paths to PYTHONPATH, only if the
|
|
|
|
# directory exists. Also preserve the current PYTHONPATH value.
|
|
|
|
# Feel free to autorun this when .zshrc loads.
|
|
|
|
function pyuserpaths() {
|
|
|
|
local targets=("python2" "python3") # bins
|
|
|
|
|
|
|
|
# Get existing interpreters.
|
|
|
|
local interps=()
|
|
|
|
for target in $targets; do
|
|
|
|
[ `command -v $target` ] && interps+=($target)
|
|
|
|
done
|
|
|
|
|
|
|
|
# Check for a non-standard install directory.
|
|
|
|
local user_base="${HOME}/.local"
|
|
|
|
[ $PYTHONUSERBASE ] && user_base=$PYTHONUSERBASE
|
|
|
|
|
|
|
|
# Add version specific paths, if:
|
|
|
|
# it exists in the filesystem;
|
|
|
|
# it isn't in PYTHONPATH already.
|
|
|
|
for interp in $interps; do
|
|
|
|
# Get minor release version.
|
|
|
|
local ver=`$interp -V 2>&1`
|
|
|
|
ver=`echo ${ver:7} | cut -d '.' -f 1,2` # The patch version is variable length, truncate it.
|
|
|
|
|
|
|
|
local site_pkgs="${user_base}/lib/python${ver}/site-packages"
|
|
|
|
[[ -d $site_pkgs && ! $PYTHONPATH =~ $site_pkgs ]] && export PYTHONPATH=${site_pkgs}:$PYTHONPATH
|
|
|
|
done
|
|
|
|
}
|
|
|
|
|
2012-03-22 05:34:19 +08:00
|
|
|
# Grep among .py files
|
2020-05-24 04:33:09 +08:00
|
|
|
alias pygrep='grep -nr --include="*.py"'
|
2013-09-10 17:33:58 +08:00
|
|
|
|
2017-01-20 18:05:01 +08:00
|
|
|
# Run proper IPython regarding current virtualenv (if any)
|
|
|
|
alias ipython="python -c 'import IPython; IPython.terminal.ipapp.launch_new_instance()'"
|
2021-09-25 04:37:09 +08:00
|
|
|
|
|
|
|
# Share local directory as a HTTP server
|
|
|
|
alias pyserver="python -m http.server"
|
2021-04-02 05:35:00 +08:00
|
|
|
|
|
|
|
|
|
|
|
## venv utilities
|
|
|
|
|
|
|
|
# Activate a the python virtual environment specified.
|
|
|
|
# If none specified, use 'venv'.
|
|
|
|
function vrun() {
|
|
|
|
local name="${1:-venv}"
|
|
|
|
local venvpath="${name:P}"
|
|
|
|
|
|
|
|
if [[ ! -d "$venvpath" ]]; then
|
|
|
|
echo >&2 "Error: no such venv in current directory: $name"
|
|
|
|
return 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [[ ! -f "${venvpath}/bin/activate" ]]; then
|
|
|
|
echo >&2 "Error: '${name}' is not a proper virtual environment"
|
|
|
|
return 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
. "${venvpath}/bin/activate" || return $?
|
|
|
|
echo "Activated virtual environment ${name}"
|
|
|
|
}
|
|
|
|
|
|
|
|
# Create a new virtual environment, with default name 'venv'.
|
|
|
|
function mkv() {
|
|
|
|
local name="${1:-venv}"
|
|
|
|
local venvpath="${name:P}"
|
|
|
|
|
|
|
|
python3 -m venv "${name}" || return
|
|
|
|
echo >&2 "Created venv in '${venvpath}'"
|
|
|
|
vrun "${name}"
|
|
|
|
}
|