Git的介绍

news/2024/11/30 1:41:17/

导出项目依赖

# 以后项目给别人需要导出项目依赖,放在项目路径下,以后在运行项目前,先安装依赖

    一般约定俗成都叫 requirements.txt,但是会有别的:req.txt  |  dev.txt
# 两种方式:
    1、虚拟环境所有装的第三方,都应该是该项目的依赖,直接导出所有第三方模块即可

        mkvirtualenv -p python 虚拟环境名
        pip freeze  > requirements.txt

    2 不需要管是虚拟环境还是真实环境,只会导出项目的依赖
        pip install pipreqs
        pipreqs . --encoding=utf-8

# 导出python项目的 依赖包

  1. 首先进入项目所在的虚拟环境(如果有的话),可以使用 source activate your_env 命令进入。
  2. 然后使用 pip freeze > requirements.txt 命令将当前环境中的所有依赖包及其版本信息导出到 requirements.txt 文件中。
  3. 最后可以将 requirements.txt 文件分享给其他人,他们可以通过 pip install -r requirements.txt 命令快速安装所需的依赖包。

软件开发模式

# 瀑布开发
    软件设计,分任务开发,测试全部,上线
# 敏捷开发
    软件分板块
        版块设计[用户],分任务开发,测试部分,上线
        版块设计[订单],分任务开发,测试部分,上线
        版块设计[商品],分任务开发,测试部分,上线
    整体测试
    上线

git介绍和安装

# 软件开发一个功能后,会把代码提交到某个位置,大家都能拿到

        首页功能开发完了,提交到git

# 现在存在的问题:
        1、多人在同一项目上开发,代码合并,多人协同开发
        2、做版本管理,版本回退,查看...
# SVN 、 GIT 能完成上述操作:
        svn 比较老,用的公司不多
        git比较流行

# git是什么?
    版本控制[软件],控制的对象是文件
    下载https://git-scm.com/downloads
            win:Git-2.43.0-64-bit.exe 下载,一路下一步安装即可
           mac:  双击安装
    安装完成:点右键,多出两个命令
                git bash here   # 会常用
                git gui here      # 用的少
    打开命令行:
                git -v

git gitlab gitee github介绍

git:软件,做版本管理的,分不同平台(win,mac)
github:网站,git远程代码仓库,全球最大的开源代码托管平台,全球最大的开源代码仓库
gitee:国内最大的开源代码托管平台(小公司,私有仓库)

gitlab:公司内部的远程仓库(公司内部这个多)
# bitbucket 给公司做代码托管的,没有开源

git使用流程

# git 有三个区:
    工作区:某个文件夹,在文件夹  新增,修改,删除,更新 文件--用户操作的位置
    暂存区:工作区的变更---提交到暂存区
    版本库:把暂存区内容---提交到版本库---文件就被版本管理了--回退到某个版本
    远程仓库:第三方:github,gitee,gitlab
# 工作流程:三个区的来回操作

git常用命令

# 初始化仓库:仓库目录下会出现 .git 文件夹,文件夹千万不要删除
        git init             # 初始化当前文件夹
        git init 文件夹 # 在当前文件夹下创建文件夹,并把新创建的文件夹作为仓库
# 查看仓库状态:
        git status 
        git status -s     #查看仓库状态的简约显示
    红色:工作区有变更,但是没有提交到暂存区  
    绿色:工作区变更提交到暂存区,但是没有提交到版本库---》还没有被版本管理起来
    白色:所有变更都被版本管理了

# 把工作区变更提交到暂存区:
        git add 文件名 文件夹
        git add .  # 所有变更

# 把暂存区提交到版本库:
        git commit -m '注释'    

        # 只要提交一次,就会有个版本号,以后根据版本号我们可以回退到任意版本

# 设置用户名和邮箱,一般写在git init之后,只设置一次

# 全局设置
git config --global user.name '用户名'
git config --global user.email '用户邮箱'
# 局部设置:
git config user.name 'xxx'
git config user.email '4@qq.com'

# 查看版本日志:  
    git log   # 能看到用户:zjq <3306@qq.com>
    git reflog
# 撤销工作区变更:
                 git checkout .   # 撤销所有暂存区的提交
                git checkout 文件名    # 撤销某一文件的暂存区提交

# 撤销暂存区提交:add的逆运算
             git reset HEAD .   # 撤销所有暂存区的提交
             git reset 文件名     # 撤销某一文件的暂存区提交
# git log 更多:
查看时间点之前|之后的日志:
        git log --after 2018-6-1
        git log --before 2018-6-1
        git reflog --after 2018-6-1
        git reflog --before 2018-6-1
查看指定开发者日志:
        git log --author author_name
        git reflog --author author_name
# 回滚到指定版本:
        回滚到上一个版本:
                    git reset --hard HEAD^
                    git reset --hard HEAD~
        回滚到上三个版本:
                    git reset --hard HEAD^^^
                    git reset --hard HEAD~3
        回滚到指定版本号的版本:
                    git reset --hard 版本号 (重点)
              eg: git reset --hard 35cb292

git log和git reflog区别

回滚到上一个版本:
        git reset --hard HEAD^
        git reset --hard HEAD~
回滚到上三个版本:
        git reset --hard HEAD^^^
        git reset --hard HEAD~3
回滚到指定版本号的版本:
        git reset --hard 版本号 (重点)
  eg: git reset --hard 35cb292
# 只要是被版本管理了,后期我们可以回退到任意版本

git忽略文件

# 在仓库中,某些文件或文件夹,不期望被git管理,不被版本管理

node_models
.idea
.vscode
__pycache__ :为了加快执行效率, 解释器会把py文件,只要执行过,就编译成views.cpython-38.pyc, 以后再运行,直接运行这个文件,速度快
项目的日志文件 

# 在仓库目录下新建一个文件:.gitignore
    标明哪些不被git管理,标明语法如下:
            如果是文件,直接写文件名
            如果是文件夹,直接写文件夹名
# 具体如下:
        文件或文件夹名:代表所有目录下的同名文件或文件夹都被过滤
        /文件或文件夹名:代表仓库根目录下的文件或文件夹被过滤

例如:
        a.txt:项目中所有a.txt文件和文件夹都会被过滤
        /a.txt:项目中只有根目录下a.txt文件和文件夹会被过滤
        /b/a.txt:项目中只有根目录下的b文件夹下的a.txt文件和文件夹会被过滤
        *x*:名字中有一个x的都会被过滤(*代表0~n个任意字符)
        空文件夹不会被提交,空包会被提交,包可以被提交(包中有一个init空文件)注意:
        # 以'#'开始的行,被视为注释.                                                                                           # 忽略掉所有文件名是 zjq.txt的文件.
                    zjq.txt
# 忽略所有生成的 html文件,
                *.html
# zjq.html是例外,不在忽略范围内
                !zjq.html
# 忽略所有.o和 .a文件.
                *.[oa]
# 后端项目的忽略文件:

luffy.log
__pycache__
*.pyc
.idea
scripts
.vscode
**/migrations/*.py
!**/migrations/__init__.py

# 空文件夹不被git管理:

          log
          __init__.py
          luffy.log
         *.log

git 多分支

# 以后再创建分支之前,先保证 所有文件都被git管理起来

创建分支:
            git branch dev     # 创建一个dev分支
查看分支:
            git branch
            * master     # 只有一个master分支

切换分支:
            git checkout dev    # 切换到dev分支
删除分支(不能自己删自己):
            git branch -d dev

合并分支:
    切换到master上
    git merge dev      # 把dev合并到当前分支

git远程仓库

# 远端的一个服务器:github、gitee、gitlab  
注册gitee账号
新建仓库
在本地执行
        git config --global user.name "liuqingzheng"
        git config --global user.email "306334678@qq.com"

# 已有仓库
        cd lqz
        git remote add origin https://gitee.com/liuqingzheng/lqz2.git   
# 添加远程仓库地址
        git push  origin master

今日思维导图:


http://www.ppmy.cn/news/1379610.html

相关文章

m序列生成器

function [m] mserial_generator(tap_set) % m序列产生器 % 输出为m序列&#xff0c;未进行极性变换。 L 2^(length(tap_set)-1)-1; x [zeros(1,(length(tap_set)-2)) 1]; for i 1:1:Lm(i)x(end);for j 1:1:length(tap_set)-1sum_vector(j)tap_set(j1)*x(j);endsum_x mod…

聊聊python中面向对象编程思想

面向对象编程思想 1、什么是面向过程 传统的面向过程的编程思想总结起来就八个字——自顶向下&#xff0c;逐步细化&#xff01; → 将要实现的功能描述为一个从开始到结束按部就班的连续的“步骤” → 依次逐步完成这些步骤&#xff0c;如果某一个步骤的难度较大&#xff…

在XCode中使用SwiftGen管理你的图片、配色、多语言文件等

SwiftGen是一个工具&#xff0c;可以为您的项目资源&#xff08;如图像、本地化字符串等&#xff09;自动生成Swift代码&#xff0c;然后你就可以像使用一个Class类一样访问你的资源了。 而且添加或更新资源后&#xff0c;SwiftGen也会自动更新用于访问资源的Class类。对于管理…

Docker学习——容器

容器是 Docker 的另一个核心概念&#xff0c;简单来说&#xff0c;容器是镜像的一个运行实例。所不同的是&#xff0c;镜像是静态的只读文件&#xff0c;而容器带有运行时需要的可写文件层&#xff0c;同时&#xff0c;容器中的应用进程处于运行状态。 创建容器 1新建容器 可以…

R语言扩展包与MaxEnt模型的集成:实现高效的物种分布模拟

在生态学研究中&#xff0c;物种分布模拟是一项至关重要的任务。它有助于我们理解物种与环境之间的复杂关系&#xff0c;预测物种在气候变化或人类活动影响下的潜在分布变化。近年来&#xff0c;随着计算机技术的不断发展&#xff0c;基于机器学习的物种分布模拟方法逐渐成为研…

鸿蒙开发(四)-低代码开发

鸿蒙开发(四)-低代码开发 本文主要介绍下鸿蒙下的低代码开发。 鸿蒙低代码是指在鸿蒙操作系统进行应用开发时&#xff0c;采用简化开发流程和减少编码量的方式来提高开发效率。 1&#xff1a;开启低代码开发 首先我们打开DevEco Studio .然后创建工程。 如图所示&#xff…

FreeRTOS学习第9篇--队列介绍

目录 FreeRTOS学习第9篇--队列介绍1. 数据传输的方法1.1 任务之间如何传输数据1.2 队列的本质 2. 队列的工作原理和实现2.1 创建队列2.2 向队列发送数据2.3 从队列接收数据 3. 使用队列进行任务间的通信3.1 通信示例3.2 同步示例 结论 FreeRTOS学习第9篇–队列介绍 本文目标&a…

用C++打印环境变量environ

#include <stdio.h> #include <unistd.h>using namespace std; int main() {extern char** environ;for(int i 0; environ[i] ! NULL; i){printf("%s\n",environ[i]);}return 0; }输出很多&#xff0c;大致如下(敏感信息用xxx代替)&#xff1a; [singl…