win10 配置 oh-my-posh

win10 配置 oh-my-posh

  • 0. 前置
  • 1. 安装
    • 1.1. 软件
    • 1.2. 字体
    • 1.3. 激活
      • 1.3.1. Git Bash
      • 1.3.2. PowerShell
  • 2. 配置
    • 2.1. 效果
    • 2.2. 说明
    • 2.3. 其他
      • 2.3.1. 新版`PowerShell`
      • 2.3.2 `conda`问题

0. 前置

这个东西毕竟是个,命令行美化工具,所以需要先有一个命令行,我这里用的是 Windows Terminal1。总之具体的细节不再赘述,安装这个的教程可以参考上文的链接,或者自行查找教程。我们在这里假设你已经有了一个配置好的终端,并且熟悉其修改基本设置。

1. 安装

1.1. 软件

网上有的教程,有在命令行用winget的,有在Microsoft Store安装的,但是可能由于网络问题,试了几次都没成功,最终还是直接去 github2下载的安装包,选了个64位的版本。

这个比较烦的是需要手动更新,毕竟是手动安装的软件。如果有更新,会在更新发布后,第一次打开终端的时候,在命令行上面弹出几行更新提示。毕竟开命令行的时候才启动了oh-my-posh,自然它也就在此时检查更新。之前还想找一下有无禁止更新的设置,没找到。

需要注意,手动更新的话,每次更新似乎会覆盖安装位置的所有文件,所以不要在安装文件夹放什么配置文件。

1.2. 字体

美化嘛,总要整点新花样,花里胡哨的字符,自然就需要一个新的字体来支持视觉效果。这里没啥说的,按照官方文档的装就行了,就是这个Meslo LGM NF。这里就不放字体链接了,去官方文档3找吧,万一他们更新了字体或者什么的。总之,下载链接大概在这个位置,摘录一段原文:

Oh My Posh was designed to use Nerd Fonts. Nerd Fonts are popular fonts that are patched to include icons. We recommend Meslo LGM NF, but any Nerd Font should be compatible with the standard themes.
 
To see the icons displayed in Oh My Posh, install a Nerd Font, and configure your terminal to use it.

1.3. 激活

1.3.1. Git Bash

大概是在配置文件里面加一行代码,配置文件的地址是:

C:\Users\UserName\.bash_profile

然后加一行激活oh-my-posh主题的代码

eval "$(oh-my-posh --init --shell bash --config D:\\Software\\Config\\oh-my-posh-themes\\jandedobbeleer.omp.json)"

反正大概意思就是,在启动Git Bash的时候,运行这行代码。然后这行代码的意思呢,是启动oh-my-posh并初始化,使用指定路径的json文件来配置主题。

1.3.2. PowerShell

首先需要说一下,这个是旧版的,详细信息如下:

PS C:\WINDOWS\system32> $psversiontableName                           Value
----                           -----
PSVersion                      5.1.19041.4170
PSEdition                      Desktop
PSCompatibleVersions           {1.0, 2.0, 3.0, 4.0...}
BuildVersion                   10.0.19041.4170
CLRVersion                     4.0.30319.42000
WSManStackVersion              3.0
PSRemotingProtocolVersion      2.3
SerializationVersion           1.1.0.1

配置文件大概是在4

C:\Users\UserName\Documents\WindowsPowerShell\profile.ps1

然后启动命令是:

oh-my-posh init pwsh --config 'D:\Software\oh-my-posh-themes\jandedobbeleer.omp.json' | Invoke-Expression

改主题的话,只要改路径使用新的json或者是直接改这个json内容都行

据使用体验来看,旧版PowerShell在我的电脑上本来加载就慢,配上oh-my-posh之后更是爆炸。

反正平常也就是命令行跑跑代码,我还是常用Git Bash。至于PowerShell,我去掉了所有的加载项,基本只在必要的时候使用,例如net命令什么的…当然cmd好像也能跑这些,而且貌似还更快。

2. 配置

2.1. 效果

官方文档已经给了不少主题,我印象貌似安装之后自带的就有很多,具体参照这个页面5,找到合适的直接更改启动命令,或者是json文件。

啊对了有必要说一句,因为我这里是手动更新的,所以主题的json文件一定要放在安装位置之外…要不然一更新文件就会被覆盖,然后主题就无了。问就是体验过,我这里就是在其他地方单独建了个文件夹。

当然了,可能逛了一圈发现没啥自己喜欢的,那也可以根据文档自己搭,或者是基于某个主题魔改一下,这都需要先读一下主题组件的相关说明,大概是这里6

说明文档6里面什么乱七八遭的组件都有,比如说电池电量、充电状态、内存占用,反正花里胡哨的,自己看着搭吧,我是以简洁为主,只保留自己需要的东西,其余的全给删了

我也魔改了一个自己的版本,效果如下:


我的配置文档如下:

{"$schema": "https://raw.githubusercontent.com/JanDeDobbeleer/oh-my-posh/main/themes/schema.json","blocks": [{"alignment": "left","segments": [{"background": "#ff479c","foreground": "#ffffff","properties": {"folder_separator_icon": " \ue0b1 ","home_icon": "~","style": "folder"},"style": "powerline","template": "<transparent>\ue0b0</> \uea83  {{ .Path }} ","type": "path"},{"background": "#fffb38","background_templates": ["{{ if or (.Working.Changed) (.Staging.Changed) }}#FF9248{{ end }}","{{ if and (gt .Ahead 0) (gt .Behind 0) }}#ff4500{{ end }}","{{ if gt .Ahead 0 }}#B388FF{{ end }}","{{ if gt .Behind 0 }}#B388FF{{ end }}"],"foreground": "#193549","leading_diamond": "\ue0b6","properties": {"branch_max_length": 25,"fetch_stash_count": true,"fetch_status": true,"fetch_upstream_icon": true},"style": "powerline","template": " {{ .UpstreamIcon }}{{ .HEAD }}{{if .BranchStatus }} {{ .BranchStatus }}{{ end }}{{ if .Working.Changed }} \uf044 {{ .Working.String }}{{ end }}{{ if and (.Working.Changed) (.Staging.Changed) }} |{{ end }}{{ if .Staging.Changed }} \uf046 {{ .Staging.String }}{{ end }}{{ if gt .StashCount 0 }} \ueb4b {{ .StashCount }}{{ end }} ","trailing_diamond": "\ue0b4","type": "git"},{"background": "#6CA35E","foreground": "#ffffff","properties": {"fetch_version": true},"style": "powerline","template": " \ue718 {{ if .PackageManagerIcon }}{{ .PackageManagerIcon }} {{ end }}{{ .Full }} ","type": "node"},{"background": "#8ED1F7","foreground": "#111111","properties": {"fetch_version": true},"style": "powerline","template": " \ue626 {{ if .Error }}{{ .Error }}{{ else }}{{ .Full }}{{ end }} ","type": "go"},{"background": "#FFDE57","foreground": "#111111","properties": {"display_virtual_env": true,"display_mode": "environment","home_enabled": true},"style": "powerline","template": "<parentBackground>\ue0b0</> \ue235 {{ if .Error }}{{ .Error }}{{ else }}{{ if .Venv }} {{ .Venv }} {{ .Full }}{{ end }}{{ end }} ","type": "python"},{"background": "#83769c","foreground": "#ffffff","properties": {"always_enabled": true},"style": "plain","template": "<parentBackground>\ue0b0</> \ueba2 {{ .FormattedMs }}\u2800","type": "executiontime"},{"background": "#00897b","background_templates": ["{{ if gt .Code 0 }}#e91e63{{ end }}"],"foreground": "#ffffff","properties": {"always_enabled": true},"style": "diamond","template": "<parentBackground>\ue0b0</> \ue23a ","trailing_diamond": "\ue0b4","type": "status"}],"type": "prompt"},{"alignment": "right","segments": [{"background": "#2e9599","foreground": "#111111","invert_powerline": true,"leading_diamond": "\ue0b6","style": "diamond","properties": {"time_format": "2006-01-02 15:04:05"},"template": " {{ .CurrentDate | date .Format }} ","trailing_diamond": "\ue0b4","type": "time"}],"type": "prompt"},{"alignment": "left","newline": true,"segments": [{"foreground": "#CD4277","style": "plain","template": "\uf071 ","type": "root"},{"foreground": "#45F1C2","style": "plain","template": "{{ if .SSHSession }}{{ if .Root }}<#CD4277>\uF0E7</> {{ end }}\ueb39 {{ .UserName }}{{ else }}\uf522 Zheng{{ end }}","type": "session"}],"type": "prompt"}],"console_title_template": "{{ .Shell }} in {{ .Folder }}","final_space": true,"version": 2
}

2.2. 说明

反正一堆乱七八遭的东西,我还是简要说一下我改的过程吧

就是这个主题,单行大概分为左右两个部分,就是左对齐和右对齐

左对齐的基本部分,按照截图第一行,从左到右依次有:当前所在目录或者路径,上一条命令的运行时间,上一条命令的运行状态。运行状态就是最后的那个像是松果一样的绿色的图标,如果上一条命令运行出错,这个图标会变红。还有就是要说一下第一个图标,最早我设置的是显示完整路径,然后去到一些比较深层的地方后,路径过长,直接换行了,然后就导致排版有些错乱,最后我选择了只显示目录,因为这样最短。

然后继续说左对齐这部分,第二行,可以看到激活conda后,出现了环境名称和python版本,这个也是我改的。在主题模板当中,环境名称是个变量,python版本也是个变量。激活环境后,我把他俩同时显示出来了。这个还有其他的改法,比如说如果当前路径下有.py文件,它也可以自动就显示这个python组件,显示python版本什么的,具体可以参照这一节7。这里还可以扩展很多乱七八遭的东西,比如其他语言的版本什么的。

接下来说一下第二行,这是我放输入光标的位置,也有其他的主题把光标放在第一行。这一行的最前面是个小太阳的图标,这就是字体里面带的那些花里胡哨的字符,具体可以在这里找找。就是只能输入英文找,我最早输的什么smile啊、rocket啊,后来发现不太喜欢,但又想不到其他的,然后我就输了单个字母,随便输个f,看看相关的所有图标。这个其实也是会变的,就是如果是管理员模式,对应linuxroot,小太阳就会变成一道闪电;如果是远程连接ssh,图标会变成那个经典的显示器。总之,参考文档乱改吧

当然,这里有些问题就是,这个小太阳看上去有点小啊。一开始不是这样的,一开始还挺大的,包括第一行的文件夹图标什么的,后来Windows Terminal更新了一次,应该是更改了字体渲染相关的部分,然后图标就变小了,后面又更新了几次,也没恢复,图标还是很小。我看Oh My Posh是有人提相关Issue8的,但很可惜回复说这是终端软件对字体的渲染问题,oh-my-posh对此暂时束手无策。贴一下原文:

@aaronecgberht 😅 Unfortunately, you cannot tweak it via OMP because that’s something about how your terminal app renders a Nerd Font. The only thing you can do is to use other icon characters in your theme config. It is easy to test which icons are rendered consistent in size on your end. Possibly helpful reference: Cheat Sheet for Nerd Font.

2.3. 其他

2.3.1. 新版PowerShell

貌似win10自带的是5.+版本,反正看上去似乎不太好用,后来又出了7.+版,建议通过微软应用商店安装,因为这样可以自动更新。

新版自带了一个命令补全的模块,PSReadline,我之前试装过,还挺有意思的。奈何基本不用PowerShell敲命令,所以对我而言没啥意义。

后来就卸掉了新版,因为确实不太常用,还占地方。

2.3.2 conda问题

我之前配置好oh-my-posh之后,conda死活都出不来。切换到没有美化的PowerShell,发现每一行前面的加括号的环境名称也没有了。我一开始还以为是曾经禁止过显示这个,后来发现并不是,而是莫名其妙地丢了conda的初始化。于是在Git BashPowerShell分别跑了下conda init,问题就解决了。当然也有一些其他不同操作9,只是不适用于我。

另外说一下,貌似conda初始化,就是在启动文件中加了几行代码,比如Git Bash里面似乎是这样:

# >>> conda initialize >>>
# !! Contents within this block are managed by 'conda init' !!
if [ -f '/d/Software/miniconda3/Scripts/conda.exe' ]; theneval "$('/d/Software/miniconda3/Scripts/conda.exe' 'shell.bash' 'hook')"
fi
# <<< conda initialize <<<

  1. 1分钟速通Win10安装Windows Terminal - 知乎 ↩︎

  2. Releases · JanDeDobbeleer/oh-my-posh ↩︎

  3. Fonts | Oh My Posh ↩︎

  4. 为 Git Bash 设置 PowerLine - 知乎 ↩︎

  5. Themes | Oh My Posh ↩︎

  6. Angular | Oh My Posh ↩︎ ↩︎

  7. Python | Oh My Posh ↩︎

  8. How do I set the size of the icon? · Issue #2445 · JanDeDobbeleer/oh-my-posh · GitHub ↩︎

  9. windows terminal中配置on-my-posh,conda虚拟环境提示不生效 - fanyfan - 博客园 ↩︎

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/277967.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

最后的挣扎 - Qt For Android on HuaWei Mate 60Pro (v4.0.0)

简介 为什么叫最后的挣扎, 其实都知道即将到来的 HarmonyOS NEXT 将抛弃Android支持&#xff0c;纯血HarmonyOS 将上线&#xff0c; 此时再说Qt for android支持Huawei HarmonyOS的设备其实并没有多少意思&#xff0c; 但恐怕在大多数基础软件完成兼容前&#xff0c; 很多人还是…

量子计算+HPC!ORNL与Riverlane、Rigetti合作研发

内容来源&#xff1a;量子前哨&#xff08;ID&#xff1a;Qforepost&#xff09; 编辑丨慕一 编译/排版丨沛贤 1000字丨8分钟阅读 近日&#xff0c;英国量子计算初创公司Riverlane和美国量子计算公司Rigetti Computing宣布将参与由美国能源部橡树岭国家实验室&#xff08;OR…

【javaWeb】在webapp中手动发布一个应用

标题 &#x1f432;一、为什么要在webapp中手动发布一个应用&#x1f389;二、手动发布步骤1.下载Tomcat2.解压并安装3.在webapps中创建文档 ✨三、总结 &#x1f432;一、为什么要在webapp中手动发布一个应用 好处解释灵活性手动发布应用程序可以根据自己的需求进行自定义配置…

【C++】了解一下编码

个人主页 &#xff1a; zxctscl 如有转载请先通知 文章目录 1. 前言2. ASCII编码3. unicode4. GBK5. 类型转换 1. 前言 看到string里面还有Template instantiations&#xff1a; string其实是basic_string<char>&#xff0c;它还是一个模板。 再看看wstring&#xff1…

195基于matlab的凸轮机构GUI界面

基于matlab的凸轮机构GUI界面 &#xff0c; 凸轮设计与仿真 绘制不同的凸轮轮廓曲线 &#xff0c;凸轮机构运动参数包括推程运动角&#xff0c;回程运动角&#xff0c;远休止角&#xff0c;近休止角。运动方式&#xff0c;运动规律。运动仿真过程可视化。内容齐全详尽。用GUI打…

el-select使用filterable下拉无法关闭得问题

这里推荐一个前端框架 sakuya / SCUI&#xff0c;他里面有个formTable&#xff0c;可以解决很多订单明细保存得问题。基本沿用element-plus的前端使用模式&#xff0c;让表单表格变的非常容易。 这个的供应商插件&#xff0c;当使用filterable后&#xff0c;点击表格重的选项&…

HarmonyOS NEXT应用开发—视频全屏切换案例

介绍 本示例介绍了Video组件和ohos.window接口实现媒体全屏的功能。 该场景多用于首页瀑布流媒体播放等。 效果图预览 使用说明&#xff1a; 点击全屏按钮&#xff0c;横屏媒体窗口。点击恢复窗口按钮&#xff0c;恢复媒体窗口。 实现步骤 在Video组件内调用 onFullscreen…

Gin 框架中前端向后端传值的几种方式介绍

我将为您详细讲解 Gin 框架中前端向后端传值的几种方式&#xff0c;并给出相应的简单例子。Gin 是一个高性能的 Web 框架&#xff0c;用于构建后端服务。在 Web 应用程序中&#xff0c;前端通常需要向后端发送数据&#xff0c;以便后端能够进行处理。以下是几种常见的前端向后端…

Vue2(六):生命周期、组件、组件的嵌套、VueComponent构造函数、单文件组件

一、生命周期 1.什么是生命周期&#xff1f; 生命周期 1.又名&#xff1a;生命周期回调函数、生命周期函数、生命周期钩子。 2.是什么&#xff1a;Vue在关键时刻帮我们调用的一些特殊名称的函数。 3.生命周期函数的名字不可更改&#xff0c;但函数的具体内容是程序员根据需求…

mybatis源码阅读系列(二)

前言 上一篇文章mybatis源码阅读系列&#xff08;一&#xff09;介绍了mybatis和原生jdbc的区别&#xff0c;并通过代码展示了两者的运行过程和结果&#xff0c;下面让我们继续详细了解下mybatis的执行过程&#xff1b; package com.wyl.mybatis.service;import com.wyl.mybat…

React三大属性---state,props,ref

react的三大属性 react的三大属性分别是state props 和ref 是传递数据的重要内容 State state是组件对象最重要的属性 包含多个key-value的组合呢 存在于组件实例对象中 基本使用 此时demo是通过onClick的回调 所以this是undefined 本来应该是window 但是局部开启了严格模…

【DL经典回顾】激活函数大汇总(十八)(ISRU附代码和详细公式)

激活函数大汇总&#xff08;十八&#xff09;&#xff08;ISRU附代码和详细公式&#xff09; 更多激活函数见激活函数大汇总列表 一、引言 欢迎来到我们深入探索神经网络核心组成部分——激活函数的系列博客。在人工智能的世界里&#xff0c;激活函数扮演着不可或缺的角色&a…

Android Studio 打包 Maker MV apk 详细步骤

一.使用RPG Make MV 部署项目&#xff0c;获取项目文件夹 这步基本都不会有问题&#xff1a; 二.安装Android Studio 安装过程参考教材就行了&#xff1a; https://blog.csdn.net/m0_62491877/article/details/126832118 但是有的版本面板没有Android的选项&#xff08;勾…

ES模块化

Node.js默认并不支持ES模块化&#xff0c;如果需要使用可以采用两种方式。方式一&#xff0c;直接将所有的js文件修改为mjs扩展名。方式二&#xff0c;修改package.json中type属性为module。 导出 默认导出 // 向外部导出内容 export let a 10 export const b "孙悟空…

Vue2 引入使用ElementUI详解

目录 1 安装2 引入2.1 全局引入2.1.1 引入2.1.2 使用 2.2 按需引入2.2.1 引入2.2.2 使用 3 总结 1 安装 推荐使用 npm 的方式安装&#xff0c;它能更好地和 webpack打包工具配合使用。&#xff08;本项目使用安装方式&#xff09; npm i element-ui -S也可以使用其他的包管理…

WebRTC:真正了解 RTP 和 RTCP

介绍 近年来&#xff0c;通过互联网进行实时通信变得越来越流行&#xff0c;而 WebRTC 已成为通过网络实现实时通信的领先技术之一。WebRTC 使用多种协议&#xff0c;包括实时传输协议 (RTP) 和实时控制协议 (RTCP)。 RTP负责通过网络传输音频和视频数据&#xff0c;而RTCP负责…

Java Swing游戏开发学习12

内容来自RyiSnow视频讲解 这一节讲的是实现游戏中的NPC(Non Player Character)非玩家角色。 添加了一个老人NPC&#xff0c;一个简单的AI&#xff08;人工智能&#xff09;拄着拐杖四处走。老人与树木、玩家的碰撞检测。 NPC四处走动 实现NPC四处走动 一开始&#xff0c;每一…

cmd常用指令

cmd全称Command Prompt&#xff0c;中文译为命令提示符。 命令提示符是在操作系统中&#xff0c;提示进行命令输入的一种工作提示符。 在不同的操作系统环境下&#xff0c;命令提示符各不相同。 在windows环境下&#xff0c;命令行程序为cmd.exe&#xff0c;是一个32位的命令…

AndroidStudio 由dolphin升级到giraffe,出现“gradle project sync failed“

1 现象描述 将AS由之前的dolphin版本升级到giraffe之后&#xff0c;接着打开以前的Android project&#xff0c;出现了"Gradle project sync failed…"的异常提示&#xff0c;在build面板中并没有出现project sync过程中报错的日志。 异常提示如下图所示&#xff1a…

springboot蛋糕订购小程序的设计与实现

摘 要 相比于以前的传统手工管理方式&#xff0c;智能化的管理方式可以大幅降低商家的运营人员成本&#xff0c;实现了蛋糕订购的标准化、制度化、程序化的管理&#xff0c;有效地防止了蛋糕订购的随意管理&#xff0c;提高了信息的处理速度和精确度&#xff0c;能够及时、准确…