README.md
· 742 B · Markdown
Исходник
# VS Code 扩展推荐
## 扩展列表
| 名称 | 扩展 ID (官方) | 扩展 ID() | 描述 |
|:---|:---|:---|:---|
| [**Even Better TOML**][6] | `tamasfe.even-better-toml` | - | 功能齐全的 TOML 支持 |
| [**Choose a License**][7] | `ultram4rine.vscode-choosealicense` | - | 为你的项目选择一个许可证 |
| [**gitignore**][8] | `codezombiech.gitignore` | - | 从 https://github.com/github/gitignore 仓库拉取 .gitignore 模板。支持.gitignore 文件的语言。 |
[6]:https://github.com/tamasfe/taplo
[7]:https://github.com/ultram4rine/vscode-choosealicense
[8]:https://github.com/CodeZombieCH/vscode-gitignore
- **微软官方:** https://marketplace.visualstudio.com/
- **Open VSX:** https://open-vsx.org/
VS Code 扩展推荐
扩展列表
| 名称 | 扩展 ID (官方) | 扩展 ID() | 描述 |
|---|---|---|---|
| Even Better TOML | tamasfe.even-better-toml |
- | 功能齐全的 TOML 支持 |
| Choose a License | ultram4rine.vscode-choosealicense |
- | 为你的项目选择一个许可证 |
| gitignore | codezombiech.gitignore |
- | 从 https://github.com/github/gitignore 仓库拉取 .gitignore 模板。支持.gitignore 文件的语言。 |
- 微软官方: https://marketplace.visualstudio.com/
- Open VSX: https://open-vsx.org/
| 1 | tamasfe.even-better-toml |
| 2 | ultram4rine.vscode-choosealicense |
| 3 | codezombiech.gitignore |
| 4 |
install
· 4.3 KiB · Text
Исходник
#!/usr/bin/env bash
BASE_URL="https://gist.asfd.cn/jetsung/vscode/raw/HEAD/"
LIST_FILE="index.txt" # 默认扩展 ID 列表文件
DESC_FILE="README.md" # 描述 Markdown 文件
IDE_CMD="code" # 默认 VSCode
FORCE=false
EXTRA=""
VERBOSE=false # -v: 只显示详细扩展信息(纯文本单行格式),不安装
# 参数解析函数
parameters() {
while getopts "s:f e:n:v" opt; do
case $opt in
s) IDE_CMD="$OPTARG" ;;
f) FORCE=true ;;
e) EXTRA="$OPTARG" ;;
n) LIST_FILE="$OPTARG" ;;
v) VERBOSE=true ;;
\?) echo "无效参数: -$OPTARG" >&2; exit 1 ;;
esac
done
shift $((OPTIND-1))
EXTRA="$EXTRA $@"
}
# 主函数
main() {
parameters "$@"
# 处理 LIST_FILE
if [[ "$LIST_FILE" != "*.*" ]] && [[ "$LIST_FILE" != *.* ]]; then
LIST_FILE="${LIST_FILE}.txt"
fi
URL_DESC="${BASE_URL}${DESC_FILE}"
if $VERBOSE; then
echo
# -v 模式:下载 README.md,先提取表格数据行(跳过标题和分隔行),然后逐行处理输出纯文本格式
curl -s --fail "$URL_DESC" | awk '
# 只处理数据行:以 "| [**" 开头(名称带链接)
/^\| \[\*\*/ {
line = $0
# 提取名称:去除 [**name**][n]
if (match(line, /\[\*\*([^*]+)\*\*\]\[\d+\]/)) {
name = substr(line, RSTART + 3, RLENGTH - 7 - length(match(line, /\[\d+\]/))) # 调整去除 [n]
# 更精确:从 ** 后到 ** 前
sub(/.*\[\*\*/, "", line)
sub(/\*\*\].*/, "", line)
name = line
} else {
name = ""
}
echo $name
# 重置 line 为原始
line = $0
# 提取官方 ID:去除 `
if (match(line, /`([^`]+)`/)) {
id_official = substr(line, RSTART + 1, RLENGTH - 2)
} else {
id_official = ""
}
# 提取其他 ID:第三列,通常 -
sub(/.*\| [^|]* \| [^|]* \| /, "", line) # 临时去除到第三列后
if (match(line, /^ ([^ |]+) /)) {
id_other = substr(line, RSTART + 1, RLENGTH - 2)
} else {
id_other = "-"
}
# 提取描述:第五列(最后一列)
if (match($0, /\| ([^|]+) \| ([^|]+) \| ([^|]+) \| (.*) \|$/)) {
desc = substr($0, RSTART + RLENGTH - length($4) - 1) # 复杂,改用 split
}
# 更可靠方式:用 split 分隔 |
split($0, fields, "|")
if (length(fields) >= 5) {
name_field = fields[2]
gsub(/^[ \t]+|[ \t]+$/, "", name_field)
# 用之前提取的 name
id_official_field = fields[3]
gsub(/^[ \t]+|[ \t]+$/, "", id_official_field)
gsub(/`/, "", id_official_field)
id_other_field = fields[4]
gsub(/^[ \t]+|[ \t]+$/, "", id_other_field)
desc_field = fields[5]
gsub(/^[ \t]+|[ \t]+$/, "", desc_field)
printf "名称: %s \n扩展ID: %s \n扩展ID: %s \n描述: %s\n\n", name, id_official_field, id_other_field, desc_field
}
}'
echo
exit 0
fi
# 非 -v 模式:正常下载 index.txt 并安装
URL_LIST="${BASE_URL}${LIST_FILE}"
echo "从 $URL_LIST 下载扩展列表..."
EXTENSIONS=$(curl -s --fail "$URL_LIST" | grep -v '^#' | grep -v '^$' | sed '/^$/d')
if [ -z "$EXTENSIONS" ]; then
echo "错误: 未获取到扩展列表或文件为空!请检查文件名(当前: $LIST_FILE)。" >&2
exit 1
fi
BASE_CMD="$IDE_CMD --install-extension"
if $FORCE; then
EXTRA="--force $EXTRA"
fi
echo "开始为 $IDE_CMD 安装扩展(命令: $BASE_CMD ... $EXTRA)"
echo "扩展列表:"
echo "$EXTENSIONS" | tr ' ' '\n'
echo "-----------------"
echo "$EXTENSIONS" | tr ' ' '\n' | while read -r ext; do
[ -z "$ext" ] && continue
echo "安装: $ext"
$BASE_CMD "$ext" $EXTRA || echo "警告: 安装 $ext 失败(可能已安装或 ID 不兼容)"
done
echo "-----------------"
echo "所有扩展安装完成!请重启 IDE 以生效。"
}
main "$@"
| 1 | #!/usr/bin/env bash |
| 2 | |
| 3 | BASE_URL="https://gist.asfd.cn/jetsung/vscode/raw/HEAD/" |
| 4 | LIST_FILE="index.txt" # 默认扩展 ID 列表文件 |
| 5 | DESC_FILE="README.md" # 描述 Markdown 文件 |
| 6 | IDE_CMD="code" # 默认 VSCode |
| 7 | FORCE=false |
| 8 | EXTRA="" |
| 9 | VERBOSE=false # -v: 只显示详细扩展信息(纯文本单行格式),不安装 |
| 10 | |
| 11 | # 参数解析函数 |
| 12 | parameters() { |
| 13 | while getopts "s:f e:n:v" opt; do |
| 14 | case $opt in |
| 15 | s) IDE_CMD="$OPTARG" ;; |
| 16 | f) FORCE=true ;; |
| 17 | e) EXTRA="$OPTARG" ;; |
| 18 | n) LIST_FILE="$OPTARG" ;; |
| 19 | v) VERBOSE=true ;; |
| 20 | \?) echo "无效参数: -$OPTARG" >&2; exit 1 ;; |
| 21 | esac |
| 22 | done |
| 23 | shift $((OPTIND-1)) |
| 24 | EXTRA="$EXTRA $@" |
| 25 | } |
| 26 | |
| 27 | # 主函数 |
| 28 | main() { |
| 29 | parameters "$@" |
| 30 | |
| 31 | # 处理 LIST_FILE |
| 32 | if [[ "$LIST_FILE" != "*.*" ]] && [[ "$LIST_FILE" != *.* ]]; then |
| 33 | LIST_FILE="${LIST_FILE}.txt" |
| 34 | fi |
| 35 | |
| 36 | URL_DESC="${BASE_URL}${DESC_FILE}" |
| 37 | |
| 38 | if $VERBOSE; then |
| 39 | echo |
| 40 | # -v 模式:下载 README.md,先提取表格数据行(跳过标题和分隔行),然后逐行处理输出纯文本格式 |
| 41 | curl -s --fail "$URL_DESC" | awk ' |
| 42 | # 只处理数据行:以 "| [**" 开头(名称带链接) |
| 43 | /^\| \[\*\*/ { |
| 44 | line = $0 |
| 45 | |
| 46 | # 提取名称:去除 [**name**][n] |
| 47 | if (match(line, /\[\*\*([^*]+)\*\*\]\[\d+\]/)) { |
| 48 | name = substr(line, RSTART + 3, RLENGTH - 7 - length(match(line, /\[\d+\]/))) # 调整去除 [n] |
| 49 | # 更精确:从 ** 后到 ** 前 |
| 50 | sub(/.*\[\*\*/, "", line) |
| 51 | sub(/\*\*\].*/, "", line) |
| 52 | name = line |
| 53 | } else { |
| 54 | name = "" |
| 55 | } |
| 56 | echo $name |
| 57 | |
| 58 | # 重置 line 为原始 |
| 59 | line = $0 |
| 60 | |
| 61 | # 提取官方 ID:去除 ` |
| 62 | if (match(line, /`([^`]+)`/)) { |
| 63 | id_official = substr(line, RSTART + 1, RLENGTH - 2) |
| 64 | } else { |
| 65 | id_official = "" |
| 66 | } |
| 67 | |
| 68 | # 提取其他 ID:第三列,通常 - |
| 69 | sub(/.*\| [^|]* \| [^|]* \| /, "", line) # 临时去除到第三列后 |
| 70 | if (match(line, /^ ([^ |]+) /)) { |
| 71 | id_other = substr(line, RSTART + 1, RLENGTH - 2) |
| 72 | } else { |
| 73 | id_other = "-" |
| 74 | } |
| 75 | |
| 76 | # 提取描述:第五列(最后一列) |
| 77 | if (match($0, /\| ([^|]+) \| ([^|]+) \| ([^|]+) \| (.*) \|$/)) { |
| 78 | desc = substr($0, RSTART + RLENGTH - length($4) - 1) # 复杂,改用 split |
| 79 | } |
| 80 | |
| 81 | # 更可靠方式:用 split 分隔 | |
| 82 | split($0, fields, "|") |
| 83 | if (length(fields) >= 5) { |
| 84 | name_field = fields[2] |
| 85 | gsub(/^[ \t]+|[ \t]+$/, "", name_field) |
| 86 | # 用之前提取的 name |
| 87 | |
| 88 | id_official_field = fields[3] |
| 89 | gsub(/^[ \t]+|[ \t]+$/, "", id_official_field) |
| 90 | gsub(/`/, "", id_official_field) |
| 91 | |
| 92 | id_other_field = fields[4] |
| 93 | gsub(/^[ \t]+|[ \t]+$/, "", id_other_field) |
| 94 | |
| 95 | desc_field = fields[5] |
| 96 | gsub(/^[ \t]+|[ \t]+$/, "", desc_field) |
| 97 | |
| 98 | printf "名称: %s \n扩展ID: %s \n扩展ID: %s \n描述: %s\n\n", name, id_official_field, id_other_field, desc_field |
| 99 | } |
| 100 | }' |
| 101 | echo |
| 102 | exit 0 |
| 103 | fi |
| 104 | |
| 105 | # 非 -v 模式:正常下载 index.txt 并安装 |
| 106 | URL_LIST="${BASE_URL}${LIST_FILE}" |
| 107 | |
| 108 | echo "从 $URL_LIST 下载扩展列表..." |
| 109 | EXTENSIONS=$(curl -s --fail "$URL_LIST" | grep -v '^#' | grep -v '^$' | sed '/^$/d') |
| 110 | |
| 111 | if [ -z "$EXTENSIONS" ]; then |
| 112 | echo "错误: 未获取到扩展列表或文件为空!请检查文件名(当前: $LIST_FILE)。" >&2 |
| 113 | exit 1 |
| 114 | fi |
| 115 | |
| 116 | BASE_CMD="$IDE_CMD --install-extension" |
| 117 | if $FORCE; then |
| 118 | EXTRA="--force $EXTRA" |
| 119 | fi |
| 120 | |
| 121 | echo "开始为 $IDE_CMD 安装扩展(命令: $BASE_CMD ... $EXTRA)" |
| 122 | echo "扩展列表:" |
| 123 | echo "$EXTENSIONS" | tr ' ' '\n' |
| 124 | echo "-----------------" |
| 125 | |
| 126 | echo "$EXTENSIONS" | tr ' ' '\n' | while read -r ext; do |
| 127 | [ -z "$ext" ] && continue |
| 128 | echo "安装: $ext" |
| 129 | $BASE_CMD "$ext" $EXTRA || echo "警告: 安装 $ext 失败(可能已安装或 ID 不兼容)" |
| 130 | done |
| 131 | |
| 132 | echo "-----------------" |
| 133 | echo "所有扩展安装完成!请重启 IDE 以生效。" |
| 134 | } |
| 135 | |
| 136 | main "$@" |
python.txt
· 143 B · Text
Исходник
ms-python.isort
ms-python.autopep8
ms-python.python
ms-python.vscode-pylance
ms-python.vscode-python-envs
ms-python.debugpy
charliermarsh.ruff
| 1 | ms-python.isort |
| 2 | ms-python.autopep8 |
| 3 | ms-python.python |
| 4 | ms-python.vscode-pylance |
| 5 | ms-python.vscode-python-envs |
| 6 | ms-python.debugpy |
| 7 | charliermarsh.ruff |
| 8 |