例如,VisualStudioCode讨论了在用户级别与工作区级别应用设置。
一方面
它可以引用您已打开的项目目录;或它可以指你在特定窗口中打开的所有内容。
上面提到的页面上写着
“工作区:这些设置存储在工作区内在.vscode文件夹中,并且仅在打开工作区时应用。"
例如,VisualStudioCode讨论了在用户级别与工作区级别应用设置。
一方面
它可以引用您已打开的项目目录;或它可以指你在特定窗口中打开的所有内容。
上面提到的页面上写着
“工作区:这些设置存储在工作区内在.vscode文件夹中,并且仅在打开工作区时应用。"
当前回答
简短回答:
使用文件夹而不是单个文件夹工作空间。
仅在需要时使用多根工作空间。当需要使用多个项目文件夹时,需要多个根工作区。当您同时处理多个相关项目时,这可能非常有用。例如,您可能有一个包含产品文档的存储库,您希望在更新产品源代码时保持其最新状态。
为什么“仅在需要时使用多根工作区”?
单文件夹工作区和文件夹之间基本上只有两个区别:
通过“文件”>“打开工作区”打开单个文件夹工作区。。。然后选择<name>.code工作区文件。通过“文件”>“打开文件夹”打开文件夹。。。然后选择文件夹。当您使用<name>.code工作空间文件打开单个文件夹工作空间时,所有特定于项目的设置都将添加到<name>/code工作空间中。使用文件夹打开项目时,所有特定于项目的设置都将保存在.vscode/settings.json文件中。
即使您花时间为单个文件夹工作区创建<name>.code工作区文件,也可以通过菜单“文件”打开该文件→ 打开文件夹。。。。根据您的访问方法,有时设置可以在.vscode/settings.json文件或<name>.code工作区文件中。最好使用一致的方法访问项目文件夹。此外,启动配置(.vscode/relaunch.json)保存在文件夹设置(.vscode/Settings.json)旁边,而不是工作区设置(<name>.code Workspace)旁边。大多数时候,您仍然需要.vscode目录。
长答案:
文件中说:
工作空间的概念使VS Code能够:配置仅适用于特定文件夹而不适用于其他文件夹的设置。保持仅在该工作区上下文中有效的任务和调试器启动配置。存储和恢复与该工作区关联的UI状态(例如,打开的文件)。仅为该工作区选择性地启用或禁用扩展。
在另一个地方,它说:
不同的设置范围:用户设置-全局应用于所有VS代码实例。工作区设置-应用于打开的文件夹或工作区并覆盖用户设置。工作区文件夹设置-应用于多根工作区的特定文件夹。覆盖用户和工作区设置。
因此,基本上有三种类型的设置:
文件夹设置(最高优先级)工作区设置用户设置(最低优先级)
您可以通过将密钥绑定指定给“首选项:打开文件夹设置”,然后使用密钥绑定来修改文件夹设置。
可以通过Ctrl+Shift+P修改工作空间设置→ 首选项:打开工作区设置。
您可以按文件修改用户设置→ 偏好→ 设置。
您的工作区设置将添加到<name>.code工作区文件中。
您的文件夹设置将保存在.vscode/settings.json文件中。
有困惑
证据1:
您可以在VS代码文档、问题和社区讨论。想一想工作空间是具有额外VS代码知识的项目的根和能力。
证据2:
VS代码“工作区”通常只是您的项目根文件夹。工作区设置以及调试和任务配置如下存储在.vscode文件夹的根目录中。
证据3:
打开文件夹与打开文件夹的视觉区别.code工作区文件可能很微妙。给你一个提示.code工作区文件已打开,用户界面的某些区域(例如,文件资源管理器的根目录)显示一个额外的(工作区)名称旁边的后缀。
困惑在哪里?
关键在于细节(文档和实现)。
文档
在文件中,他们说不同的地方有不同的东西。没有一致性。
在一个地方,他们说:
VS Code为设置提供了两个不同的范围:用户设置-全局应用于您打开的任何VS代码实例的设置。工作区设置-存储在工作区内的设置,仅在工作区打开时应用。
在另一个地方,他们说:
不同的设置范围:用户设置-全局应用于所有VS代码实例。工作区设置-应用于打开的文件夹或工作区并覆盖用户设置。工作区文件夹设置-应用于多根工作区的特定文件夹。覆盖用户和工作区设置。
所以,基本上他们并没有一直说有三个层次的设置。请特别查看他们文档的标题以了解设置。标题为“用户和工作区设置”(注意标题中缺少文件夹设置)。在讨论设置优先级时,它只提到一次“工作区文件夹”设置。
实施
文件中说:
工作区设置允许您在上下文中配置设置已打开的工作区,并始终覆盖全局用户设置。它们物理存储在一个JSON文件中及其位置取决于您是将文件夹作为工作区打开还是打开.code工作区文件。
因此,基本上,当没有任何工作空间时(例如,您没有使用<name>.code工作空间打开项目),您可以Ctrl+Shift+P→ 首选项:打开工作区设置,它会打开.vscode/Settings.json文件(实际上是用于文件夹设置而不是工作区设置的,尽管名称明确表示为打开工作区)。
您可能已经在长答案中注意到:“他们”没有保留任何直接访问文件夹设置的简单方法(您必须为“首选项:打开文件夹设置”命令分配一个键绑定,然后使用键绑定。您甚至无法使用Ctrl+Shift+P直接从命令托盘访问此“命令”)。
此外,您必须使用“首选项:打开工作区设置”修改文件夹设置(请注意,您正在使用“打开工作区”修改“文件夹设置”)。首选项:打开工作区设置是否修改文件夹设置或工作区设置取决于您访问项目的方式(使用菜单“文件”→ 打开文件夹。。。或<name>.code工作区文件)。
他们试图把一件简单的事情过于简单化,使之变得困难。
其他回答
在一些调查中,答案似乎是(a)。
当我更改设置时,设置文件会进入项目目录中的.vscode目录。
如果Visual Studio代码是新安装的;
单击扩展,搜索“python”并单击安装单击菜单“视图”→ 探索者如果没有文件夹,则将文件夹添加到“工作区”(菜单“文件”→ 将文件夹添加到工作区)如果要使用虚拟Python环境,请单击菜单“文件”→ 偏爱→ 设置
单击窗口右上角的“{}打开设置JSON”,然后将路径添加到虚拟环境中的python.exe文件:
{
"python.pythonPath": "C:\\PathTo\\VirtualENV\\python.exe"
}
启动新终端并检查是否选择了正确的Python解释器
您可以在工作区级别保存设置,也可以在工作空间中打开多个文件夹。如果你想做这两件事,可以使用工作区,否则,只需打开一个文件夹。
Visual Studio代码工作区是项目文件夹和文件的列表。工作区可以包含多个文件夹。您可以自定义工作区的设置和首选项。
工作空间只是一个扩展名为(.code workspace)的文本文件。你可以用文本编辑器打开它来查看它。我也对工作区的想法以及如何在Visual Studio代码中实现它感到沮丧。我找到了一种适合我的方法。
从单个“项目”文件夹开始。
打开Visual Studio代码并关闭所有打开的工作区、文件或文件夹。在浏览器中,您应该只看到“打开的编辑器”和“没有打开的文件夹”。
从菜单栏→ 文件→ 打开文件夹。。。。导航到要放置文件夹的位置,然后右键单击以打开新文件夹。根据需要命名,然后单击“选择文件夹”。它将显示在*Visual Studio代码资源管理器中。
现在从菜单文件→ 将工作区另存为……命名工作区并将其保存在您希望保留所有工作区的任何位置(不一定是项目文件夹所在的位置)。我把我的全部放在一个名为“Visual Studio代码工作区”的文件夹中。
它将保存为(.code工作区)文件,并且只是它包含(或指向)的所有文件和文件夹的索引,无论它们位于硬盘驱动器上的任何位置。你可以用文本编辑器打开它来查看它。关闭您创建的文件夹并关闭Visual Studio代码。
现在找到您的工作区“文件”并双击它。这将打开Visual Studio代码以及您在工作区中创建的文件夹。或者您可以打开Visual Studio代码并使用“打开工作区”。
从Visual Studio代码工作区中创建的任何文件夹都将位于第一个文件夹中。如果要添加更多顶级文件夹,请首先在需要的位置创建它们,然后使用Visual Studio代码中的“添加到工作区..”。
这是了解工作空间的必读内容。
正如许多人所指出的,多根工作区是VisualStudioCode工作区概念变得相关的地方。
但为什么还有另一个问题。
因此,这里是Eclipse IDE用户指南的摘录,其中包含了正确的工作空间概念(与Visual Studio代码完全不同,如果您需要Visual Studio代码,则不应切换到Eclipse-但您可以阅读文档,因为它们解释正确):
Eclipse中使用Git存储库的注意事项短篇小说使用EGit设置Git存储库时,对于创建“高效”(而不是“游乐场”)存储库有两个建议:不要在Eclipse工作区中创建存储库。克隆或创建存储库时要小心。确保正确使用Git共享向导。不要创建以Eclipse项目为根的存储库。确保正确使用Git共享向导。第一个错误发生在克隆或创建存储库期间指定工作区文件夹时。当您在工作区中手动创建的Eclipse项目中使用Git共享向导而不采取预防措施时(该向导已在最新版本中修复),这两个错误都会发生。下面是这些建议的一些动机。更长的故事Eclipse工作区和存储库工作目录Git存储库可以用不同的方式创建,例如从现有存储库克隆、从头创建或使用EGit共享向导。在任何情况下(除非您创建了一个“裸”存储库,但这里没有讨论),新存储库本质上是本地硬盘上的一个文件夹,其中包含“工作目录”和元数据文件夹。元数据文件夹是一个名为“.git”的专用子文件夹,通常称作“.git文件夹”。它包含实际的存储库(即Commits、References、日志等)。元数据文件夹对Git客户端完全透明,而工作目录用于将当前签出的Repository内容作为工具和编辑器的文件公开。通常,如果要在Eclipse中使用这些文件,则必须以某种方式将它们导入Eclipse工作区。为此,最简单的方法是签入.project文件,“导入现有项目”向导可以从中轻松创建项目。[...]含意上述内容具有以下含义:将项目作为存储库的根文件夹可能不是一个好主意。原因是您永远无法将另一个项目添加到此存储库,因为.project文件将占用根文件夹;您仍然可以将项目添加为子文件夹,但这种项目嵌套方式会导致很多问题。为了添加另一个项目,您必须将该项目移动到存储库中的子文件夹,并将第二个项目添加为另一个子文件夹,然后才能提交此更改。将存储库保留在Eclipse工作区之外是一个好主意。这有几个原因:新的Repository将Eclipse工作区的完整文件夹结构视为(潜在的)内容。这可能会导致性能问题,例如,在提交之前计算更改时(例如,这将扫描完整的.metadata文件夹);通常情况下,工作区将包含死文件夹(例如删除的项目),这些文件夹在语义上与EGit无关,但无法轻易排除。元数据(.git-)文件夹将是EclipseWorkspace的子文件夹。目前尚不清楚这是否会导致Eclipse不需要的文件夹遍历。通过销毁Eclipse工作区,您可以轻松地销毁存储库。
尽管如此,Visual Studio也做到了这一点;为什么微软决定忽略Visual Studio代码中的解决方案(.sln)和项目(.vcxproj)概念,这很有趣。