Django实现音乐网站 ⒆

使用Python Django框架做一个音乐网站,

本篇主要为排行榜功能及音乐播放器部分功能实现。

目录

推荐排行榜优化

设置歌手、单曲跳转链接

排行榜列表渲染优化

视图修改如下:

模板修改如下:

单曲详情修改

排行榜列表

设置路由

视图处理

模板渲染

设置跳转入口

播放器功能开发

设置路由

模板页面

脚本渲染

列表渲染和播放器实现

音乐播放器列表展示关闭

总结


推荐排行榜优化

设置歌手、单曲跳转链接

因为歌手、单曲功能页面已开发,现在终于可以设置跳转链接。

内容如下:

<div class="top_info"><p class="song_name"><a href="{% url 'player:album_song' %}?sid={{item.id}}">{{ item.name }}</a></p><p class="singler"><a href="{% url 'player:singer_detail' jitem.singler.id %}">{{ item.singler.name }}</a></p>
</div>

 

排行榜列表渲染优化

之前排行榜是通过视图多个集合变量分别进行渲染,在模板页面要写五个排行版模块,分别进行渲染对应的排行榜,经过尝试后整理到一个总排行榜列表集。

视图修改如下:
def index(request):""" 显示首页 """# 获取首页轮播图carousels = Carousel.objects.all()# 推荐歌单 选播放量最多的五个songsheets = SongSheet.objects.order_by('-playnum').all()[0:5]# 推荐排行榜rank_alls = [# 热歌榜 取播放量最多的五个Singe.objects.order_by('-playnum').all()[0:5],# 新歌榜 取最新的五个Singe.objects.order_by('-id').all()[0:5],# 飙升榜Singe.objects.order_by('id').all()[0:5],# 欧美榜Singe.objects.order_by('-id').all()[0:5],# 日韩榜Singe.objects.order_by('id').all()[0:5]]# 推荐歌手 取单曲最多的六个singlers = Singler.objects.order_by('-singe_num').all()[0:6]return render(request, 'index/index.html', locals())

模板修改如下:

两套循环嵌套,外循环渲染父盒子,内循环展示排行榜中列表内容;

通过判断forloop.couter来调用相应排行榜背景图。

<div class="recommend_rank"><div class="title"><div class="name">推荐排行榜</div><ul><li><a href="#">更多></a></li></ul></div><div class="list">{% for rankitem in rank_alls %}<div class="bank"><div class="bank_top"><div class="img"><img class="img_tip" src="{% static 'images/' %}b{{forloop.counter}}.png" alt=""></div><img class="img_bg" src="{% static 'images/' %}b{{forloop.counter}}_{{forloop.counter}}.jpg" alt=""></div><ul class="bank_list">{% for hot in rankitem %}<li>{% if forloop.counter == 1 %}<div class="top_img top1"></div>{% elif forloop.counter == 2 %}<div class="top_img top2"></div>{% elif forloop.counter == 3 %}<div class="top_img top3"></div>{% else %}<div class="top_index">{{forloop.counter}}</div>{% endif %}<div class="top_info"><p class="song_name"><a href="{% url 'player:album_song' %}?sid={{hot.id}}">{{ hot.name }}</a></p><p class="singler"><a href="{% url 'player:singer_detail' hot.singler.id %}">{{ hot.singler.name }}</a></p></div></li>{% endfor %}</ul></div>{% endfor %}</div>
</div>
<!--推荐排行榜结束-->

单曲详情修改

因为之前单曲详情视图处理为查询相应专辑和单曲信息,

需要传递两个参数:即专辑id和单曲id。

但是通过排行榜跳转单曲详情,没有专辑id,故需要修改原来的处理。

通过单曲反向查询所属专辑信息。

内容如下:

def album_song(request):""" 专辑中单曲详情 """sid = request.GET.get('sid')song_info = Singe.objects.filter(id=sid).first()# 反向查询专辑info = song_info.album_set.first()# 歌词处理lyrics = []if song_info:lyrics = read_lyric(song_info.lyric)return render(request, 'album/song.html', locals())

排行榜列表

设置路由

在子应用文件夹中urls.py中新增一条记录。

# 排行榜
path('rank', views.rank, name='rank'),

视图处理

榜单列表需要展示各个排行榜所有一定时间段中上榜单曲列表;

因为前期单曲没有与类型表关联,目前就只能做一个类似的功能。

下方代码中处理了分页查询;通过id来区别类型进行排序;

设置了榜单的名称,更新时间是取单曲列表中时间最晚的一个时间。

def rank(request):""" 排行榜 """id = int(request.GET.get('id', 1))page = int(request.GET.get('page', 1))singe_db = Singe.objectsif id == 1:song_list = singe_db.order_by('-id').all()rank_name = '新歌榜'elif id == 2:song_list = singe_db.order_by('-playnum').all()rank_name = '热歌榜'elif id == 3:song_list = singe_db.order_by('playnum').all()rank_name = '飙升榜'elif id == 4:song_list = singe_db.order_by('-id').all()rank_name = '抖音歌曲榜'elif id == 5:song_list = singe_db.order_by('id').all()rank_name = '万物DJ榜'else:song_list = singe_db.order_by('-playnum').all()rank_name = '会员畅听榜'# 实例化Paginatorpage_num = 20paginator = Paginator(song_list, page_num)try:res = paginator.page(page)except PageNotAnInteger:res = paginator.page(1)except EmptyPage:res = paginator.page(paginator.num_pages)list_num = len(res)# 榜单更新时间updatetime = date.today()for item in song_list:if updatetime.ctime() < item.updatetime.ctime():updatetime = item.updatetimereturn render(request, 'rank/index.html', locals())

模板渲染

在templates文件夹下创建rank文件夹,并在其中创建index.html文件。

其他渲染都大同小异,主要有一点新的东西,因为榜单数据比较多,在第一页时候有个前三名标识,需要区别处理第二页之后的序列号和相应标识处理,这里使用了模板中的过滤器。

内容如下:

{% extends 'common/base.html' %}
{% load static %}{% block title %}我的音乐{% endblock title %}{% block content %}
<link rel="stylesheet" href="{% static 'css/rank.css' %}"><!--导航条开始-->
<div class="header"><img src="{% static 'images/logo.png' %}" class="logo" alt=""><ul><li><a href="{% url 'player:index' %}">推荐</a></li><li><a href="javascript:void(0)" class="selected">排行榜</a></li><li><a href="{% url 'player:singer' 1 '#' %}">歌手</a></li><li><a href="{% url 'player:songsheet' %}">歌单</a></li></ul>
</div>
<!--导航条结束-->
<div class="main_con"><div class="con_l"><div class="con"><div class="tabs flex_c"><span class="active">官方</span><span class="">特色</span><span class="">场景</span></div><ul class="tab_con"><li class="flex_c active"><img alt="" class="cover" data-src="{% static 'images/rank_list_1.png' %}" src="{% static 'images/rank_list_1.png' %}" lazy="loaded"><div class="item_info"><p class="name"><a href="{% url 'player:rank' %}?id=1">新歌榜</a></p><p class="time">今日更新</p></div></li><li class="flex_c active"><img alt="" class="cover" data-src="{% static 'images/rank_list_2.png' %}" src="{% static 'images/rank_list_2.png' %}" lazy="loaded"><div class="item_info"><p class="name"><a href="{% url 'player:rank' %}?id=2">热歌榜</a></p><p class="time">今日更新</p></div></li><li class="flex_c active"><img alt="" class="cover" data-src="{% static 'images/rank_list_3.png' %}" src="{% static 'images/rank_list_3.png' %}" lazy="loaded"><div class="item_info"><p class="name"><a href="{% url 'player:rank' %}?id=3">飙升榜</a></p><p class="time">今日更新</p></div></li><li class="flex_c active"><img alt="" class="cover" data-src="{% static 'images/rank_list_4.png' %}" src="{% static 'images/rank_list_4.png' %}" lazy="loaded"><div class="item_info"><p class="name"><a href="{% url 'player:rank' %}?id=4">抖音歌曲榜</a></p><p class="time">今日更新</p></div></li><li class="flex_c active"><img alt="" class="cover" data-src="{% static 'images/rank_list_5.png' %}" src="{% static 'images/rank_list_5.png' %}" lazy="loaded"><div class="item_info"><p class="name"><a href="{% url 'player:rank' %}?id=5">万物DJ榜</a></p><p class="time">今日更新</p></div></li><li class="flex_c active"><img alt="" class="cover" data-src="{% static 'images/rank_list_6.png' %}" src="{% static 'images/rank_list_6.png' %}" lazy="loaded"><div class="item_info"><p class="name"><a href="{% url 'player:rank' %}?id=6">会员畅听榜</a></p><p class="time">今日更新</p></div></li></ul></div></div><div class="con_r"><div><div><span class="title">{{rank_name}}</span> <span class="update_time">更新时间:{{updatetime}}</span></div><div class="btns"><button class="play bg_primary"><i class="glyphicon glyphicon-play"></i>&nbsp;<span>立即播放</span></button><button><i class="glyphicon glyphicon-plus"></i>&nbsp;<span>添加</span></button><button><i class="glyphicon glyphicon-heart"></i>&nbsp;<span>收藏</span></button></div><div class="list_out"><div class="list_head head_name_rank" style=""><ul class="flex_c"><li class="head_num">序号</li><li class="head_name">歌曲</li><li class="head_artist">歌手</li><li class="head_album">发布时间</li><li class="head_time">时长</li></ul></div><ul class="rank_list">{% for item in res %}<li class="song_item flex_c"><div class="song_rank flex_c">{% if page == 1 %}{% if forloop.counter == 1 %}<div class="rank_num top1"></div>{% elif forloop.counter == 2 %}<div class="rank_num top2"></div>{% elif forloop.counter == 3 %}<div class="rank_num top3"></div>{% else %}<div class="rank_num"><span>{{forloop.counter}}</span></div>{% endif %}{% else %}<div class="rank_num"><span>{{forloop.counter|add:page_num}}</span></div>{% endif %}<div class="status"></div></div><div class="song_name flex_c"><a title="{{item.name}}" href="{% url 'player:album_song' %}?sid={{item.id}}" class="name">{{item.name}}</a></div><div class="song_artist"><span title="{{item.singler.name}}">{{item.singler.name}}</span></div><div class="song_album"><span>{{item.addtime}}</span></div><div class="song_time"><span>{{item.get_song_duration}}</span></div><div class="song_opts flex_c"><i class="glyphicon glyphicon-plus"></i><i class="glyphicon glyphicon-play"></i><i class="glyphicon glyphicon-heart"></i></div></li>{% endfor %}</ul>{% if list_num < 1 %}<!--设置无数据内容--><div class="nodata flex_c"><div class="inner"><img src="{% static 'images/nodata.png' %}"alt="" class="nodata_img"><div class="tip"><p>暂无相关数据</p></div></div></div>{% endif %}<div class="loading-mask" style="display: none;"><div class="loading-wrap"><div class="load"><span class="side1"></span> <spanclass="side2"></span> <span class="mid"></span><span class="side2"></span> <spanclass="side1"></span></div></div></div></div>{% if list_num > 0 %}<!--设置分页页码--><div class="page"><i class="li-page glyphicon glyphicon-menu-left notPointer"></i><ul>{% for index in res.paginator.page_range %}{% if res.number == index %}<li><a href="#" class="notCursor currentPage">{{index}}</a></li>{% else %}<li><a href="{% url 'player:rank' %}?page={{index}}">{{index}}</a></li>{% endif %}{% endfor %}</ul><i class="glyphicon glyphicon-menu-right li-page"></i></div>{% endif %}</div></div>
</div>{% endblock content %}

设置跳转入口

点击推荐排行榜中更多按钮,进入排行榜列表。

内容如下:

<div class="title"><div class="name">推荐排行榜</div><ul><li><a href="{% url 'player:rank' %}">更多></a></li></ul>
</div>

播放器功能开发

其他功能大致算完成了,开始做播放音乐的功能开发。

播放器设置在网站的底部,采用固定悬浮;

可以左右切换音乐,设置音量,查看播放音乐列表。

设置路由

主要用来获取播放器音乐列表信息。

# 播放器列表
path('play_list', views.play_list, name='play_list'),

模板页面

播放器的主要功能采用之前使用html做的播放器,

直接嵌入到django音乐网站基类模板(templates/common/base.html)的底部。

内容如下:

<div id="music_all"><div class="music_main" style="opacity:1;background:#fff"><div class="music_left"><img class="music_img" id="music_img" src="{% static 'images/s1.jpg' %}" alt=""></div><audio id="player"><source src="/media/uploads/1691649371/七里香_-_周杰伦.mp3" type="audio/mpeg">您的浏览器不支持 audio 元素。</audio><div class="play_left"><div class="music_title"><span class="music_name">七里香 – 周杰伦</span><span class="totalTimeSpan">/04:59</span><span class="playTimeSpan">00:00</span></div><div class="music_rate"><div class="music-progress"></div></div></div><div class="play_right"><i class="glyphicon glyphicon-step-backward" id="music_prev"></i><i class="glyphicon glyphicon-play" id="music_dian"></i><i class="glyphicon glyphicon-step-forward" id="music_next"></i></div><div class="music_right"><ul><li><i class="glyphicon glyphicon-th-list" id="setList"></i></li><li><i class="glyphicon glyphicon-volume-up" id="setVolume"></i></li><li><div class="slider"><input type="range" id="volume" min="0" max="100" value="0"></div></li></ul></div></div><div class="songList" style="display:none"><div class="list_top flex_c"><div id="play_title"></div><div class="flex_c"><div class="clear_all"><i class="glyphicon glyphicon-trash"></i> <spanclass="clear_btn">清空列表</span></div><i class="close glyphicon glyphicon-remove"></i></div></div><div class="list_con"><div id="play_list" style="transition-timing-function: cubic-bezier(0.23, 1, 0.32, 1);transition-duration: 0ms; transform: translate(0px) scale(1) translateZ(0px);overflow-y: scroll;height:400px;"></div><div style="position: absolute; z-index: 9999; width: 7px; bottom: 2px; top: 2px; right: 1px; overflow: hidden;"class="bscroll-vertical-scrollbar"><div style="box-sizing: border-box; position: absolute; background: rgba(0, 0, 0, 0.5); border: 1px solid rgba(255, 255, 255, 0.9); border-radius: 3px; width: 100%; transition-duration: 0ms; height: 190px; transform: translateY(0px) translateZ(0px); transition-timing-function: cubic-bezier(0.23, 1, 0.32, 1);"class="bscroll-indicator"></div></div></div></div>
</div>

效果:

脚本渲染

使用JavaScript来实例化audio的提供的接口方法,并结合后台数据进行渲染和调用audio来实现播放器功能。

列表渲染和播放器实现

内容如下:

window.onload = function () {// 绑定音频元素var $player = document.getElementById('player');// 绑定播放按钮var $dian = document.getElementById('music_dian');// 设置音频初始属性var volume_num = 0.5;// 当前歌曲索引var currentIndex = 0;// 设置播放列表var music_list = [{'id': 1,'cover': '/static/images/s1.jpg','singer': '周杰伦','song_name': '七里香','song_path': '/media/uploads/1691649371/七里香_-_周杰伦.mp3'},];// 设置播放器音乐列表var play_list = document.getElementById('play_list');var play_title = document.getElementById('play_title');// 初始化设置setInit();// 绑定音频控制开关$dian.onclick = function () {if (this.classList == 'glyphicon glyphicon-play') {this.className = 'glyphicon glyphicon-pause';$player.play();} else {// layui-icon-pausethis.className = 'glyphicon glyphicon-play';$player.pause();}};// 设置播放器初始属性function setInit() {// 设定音量$player.volume = volume_num;$('#volume').val(volume_num * 100);// 通过同步方式获取播放列表信息$.ajaxSettings.async = false;$.getJSON('/play_list', {}, function (res) {// 赋值播放列表music_list = res.list;});// 设定歌曲封面$('#music_img').attr('src', '/media/' + music_list[0].cover);// 设定歌曲名称和歌手$('.music_name').text(music_list[0].song_name + ' - ' + music_list[0].singer);// 设定歌曲路径$player.src = '/media/' + music_list[0].song_path;// 设置播放器音乐列表set_media_list(music_list)}// 监听播放器播放时间改变事件$player.addEventListener('timeupdate', function () {// 当前播放时间var currentTime = $player.currentTime;// 总时间var totalTime = $player.duration;// 当是数字的时候if (!isNaN(totalTime)) {// 得到播放时间与总时长的比值var rate = currentTime / totalTime;// 设置时间显示// 播放时间$('.playTimeSpan').text(musicTime(currentTime));// 总时长$('.totalTimeSpan').text('/' + musicTime(totalTime));// 设置进度条$('.music-progress').css('width', rate * 441 + 'px');}});// 设置音量$('#volume').change(function () {volume_num = $(this).val();$player.volume = volume_num * 0.01});// 上一首$('#music_prev').click(function () {if (currentIndex > 0) {currentIndex -= 1;} else {// 切换到最后一首currentIndex = music_list.length - 1;}// 设置播放标识为暂停$dian.className = 'glyphicon glyphicon-play';// 播放时间$('.playTimeSpan').text('00:00');// 设置歌曲进度归零$('.music-progress').css('width', '1px');// 设置歌曲setMusic();});// 下一首$('#music_next').click(function () {if (currentIndex < (music_list.length - 1)) {currentIndex += 1;} else {// 切换为第一首currentIndex = 0;}// 设置播放标识为暂停$dian.className = 'glyphicon glyphicon-play';// 播放时间$('.playTimeSpan').text('00:00');// 设置歌曲进度归零$('.music-progress').css('width', '1px');// 设置歌曲setMusic();});// 设置播放器歌曲信息function setMusic() {// 设定歌曲封面$('#music_img').attr('src', '/media/' + music_list[currentIndex].cover);// 设定歌曲名称和歌手$('.music_name').text(music_list[currentIndex].song_name +' - ' + music_list[currentIndex].singer);// 设定歌曲路径$player.src = '/media/' + music_list[currentIndex].song_path;}// 歌曲时长(00:00)function musicTime(sens) {// 分var m = parseInt(sens / 60);// 秒var s = parseInt(sens % 60);// 补零m = m > 9 ? m : "0" + m;s = s > 9 ? s : "0" + s;return m + ":" + s;}// 设置音乐播放器列表function set_media_list(music_list) {var play_html = '';for (var i = 0; i < music_list.length; i++) {if (i) {play_html += '<div class="flex_c list_item" style="pointer-events: auto;">' +'<div class="list_idx">' + (i + 1) + '' +'<span class="playing" style="display: none">';} else {play_html += '<div class="flex_c list_item active_cur" style="pointer-events: auto;">' +'<div class="list_idx">' + (i + 1) + '' +'<span class="playing">';}play_html += '<span class="side1 pause"></span>' +'<span class="side2 pause"></span>' +'<span class="side3 pause"></span>' +'</span>' +'</div>' +'<div class="song_name">' +'<a href="/album/song?sid='+ music_list[i].id +'" title="' + music_list[i].song_name + '" ' +'target="_blank">' + music_list[i].song_name + '</a>' +'</div>' +'<div class="artist">' +'<a href="/singer/detail/'+music_list[i].singer_id +'" ' +'class="" title="' + music_list[i].singer + '" target="_blank">' + music_list[i].singer + '</a>' +'</div>' +'<div class="time">' + music_list[i].duration + '</div>' +'<div class="song_opts flex_c">' +'<i title="添加歌曲" class="glyphicon glyphicon-plus"></i>&nbsp;&nbsp;' +'<i title="收藏歌曲" class="glyphicon glyphicon-heart"></i>&nbsp;&nbsp;' +'<i title="下载歌曲" class="glyphicon glyphicon-save"></i>&nbsp;&nbsp;' +'<i title="删除歌曲" class="glyphicon glyphicon-trash"></i>&nbsp;&nbsp;' +'</div>' +'</div>';}play_title.innerHTML='<span class="text">播放列表</span> <span class="num">(共'+ music_list.length +'首)</span>';play_list.innerHTML=play_html;console.log(play_title);}
};

音乐播放器列表展示关闭

可通过底部播放器列表icon来打开和关闭播放列表;

也可以通过播放列表中关闭icon来隐藏播放列表。

内容如下:

$('#setList').click(function(){// 展示关闭音乐播放器列表var songList = $('.songList');if (songList.css('display') == 'none') {songList.show();}else{songList.hide();}
})$('.close').click(function(){// 关闭播放列表$('.songList').hide();
});

总结

本篇主要是推荐页-排行榜功能改为动态数据及播放器功能部分实现,可以播放音乐和左右切换以及查看播放音乐列表。

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

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

相关文章

MySQL建表操作和用户权限

1.创建数据库school&#xff0c;字符集为utf8 mysql> create database school character set utf8; 2.在school数据库中创建Student和Score表 mysql> create table school.student( -> Id int(10) primary key, -> Stu_id int(10) not null, -> C_n…

【Python 零基础入门】 Numpy

【Python 零基础入门】第六课 Numpy 概述什么是 Numpy?Numpy 与 Python 数组的区别并发 vs 并行单线程 vs 多线程GILNumpy 在数据科学中的重要性 Numpy 安装Anaconda导包 ndarraynp.array 创建数组属性np.zeros 创建np.ones 创建 数组的切片和索引基本索引切片操作数组运算 常…

C# 使用 RSA 加密算法生成证书签名产生“The system cannot find the file specified”异常

使用 C# 中 RSA&#xff08;System.Security.Cryptography.RSA&#xff09; 加密算法生成证书签名进行身份验证&#xff0c;在 VS2022 开发工具本地运行应用程序一切正常。 但将应用程序部署到远程服务器&#xff08;如&#xff1a;Azure App Services&#xff09;&#xff0c…

alsa音频pcm设备之i2c调试

i2cdetect 列举 I2C bus i2cdetect -l ls /dev/i2c* 列出I2C bus i2c-7 上面连接的所有设备,并得到i2c设备地址 i2cdetect -y 7 发现i2c设备的位置显示为UU或表示设备地址的数值,UU表示设备在driver中被使用. I2cdump i2c设备大量register的值 i2cdump -y 7 0x40 I2cset设置…

ROS中的图像数据

无论是USB摄像头还是RGBD摄像头&#xff0c;发布的图像数据格式多种多样&#xff0c;在处理这些数据之前&#xff0c;我们首先需要了解这些数据的格式。 二维图像数据 连接USB摄像头到PC端的USB接口&#xff0c;通过以下命令启动摄像头&#xff1a; roslaunch usb_cam usb_ca…

Spring Boot中的Redis自动配置与使用

Spring Boot中的Redis自动配置与使用 Redis是一种高性能的开源内存数据库&#xff0c;常用于缓存、会话管理和消息队列等场景。Spring Boot提供了自动配置来简化在Spring应用程序中使用Redis的过程。本文将介绍Spring Boot中的Redis自动配置是什么以及如何使用它来轻松集成Red…

分权分域有啥内容?

目前的系统有什么问题&#xff1f; 现在我们的系统越来越庞大&#xff0c;可是每一个人进来的查看到的内容完全一样&#xff0c;没有办法灵活的根据不同用户展示不同的数据 例如我们有一个系统&#xff0c;期望不同权限的用户可以看到不同类型的页面&#xff0c;同一个页面不…

动态盘转换为基本盘

问题描述 不小心将磁盘0&#xff08;C和D是基本盘&#xff0c;蓝颜色&#xff09;改成了动态盘&#xff08;C和D是动态盘&#xff0c;橘黄色&#xff09;&#xff1f;如何修改回来呢&#xff1f; 解决方案&#xff1a; 使用DiskGenius将动态磁盘转换为基本磁盘 操作之前一定…

Linux友人帐之系统管理与虚拟机相关

一、虚拟机相关操作 1.1虚拟机克隆 虚拟机克隆是指将一个已经安装好的虚拟机复制出一个或多个完全相同的副本&#xff0c;包括虚拟机的配置、操作系统、应用程序等&#xff0c;从而节省安装和配置的时间和资源。 虚拟机克隆的主要用途有&#xff1a; 创建多个相同或相似的虚拟…

并发编程——1.java内存图及相关内容

这篇文章&#xff0c;我们来讲一下java的内存图及并发编程的预备内容。 首先&#xff0c;我们来看一下下面的这两段代码&#xff1a; 下面&#xff0c;我们给出上面这两段代码在运行时的内存结构图&#xff0c;如下图所示&#xff1a; 下面&#xff0c;我们来具体的讲解一下。…

CubeMX+BabyOS 使用方法

MCU&#xff1a;STM32G030F 编译器&#xff1a;MDK 托管工具&#xff1a;Sourcetree CubeMX创建工程 BabyOS克隆 添加子模块 git submodule add https://gitee.com/notrynohigh/BabyOS.git BabyOS 切换dev 分支 查看当前分支 git branch -a 切换本地分支到dev git che…

【JVM系列】- 启航·JVM概论学习

启航JVM概论 &#x1f604;生命不息&#xff0c;写作不止 &#x1f525; 继续踏上学习之路&#xff0c;学之分享笔记 &#x1f44a; 总有一天我也能像各位大佬一样 &#x1f3c6; 博客首页 怒放吧德德 To记录领地 &#x1f31d;分享学习心得&#xff0c;欢迎指正&#xff0c…

Python中使用IDLE调试程序

在IDLE中&#xff0c;使用菜单栏中的“Debug”对IDLE打开的python程序进行调试。 1 打开调试开关 选择IDLE菜单栏的“Debug->Debugger”&#xff0c;如图1①所示&#xff1b;此时在IDLE中会显示“[DEBUG ON]”&#xff0c;即“调试模式已打开”&#xff0c;如图1②所示&am…

【ftp篇】 vsftp(ftp) 每天生成一个动态密码

这里写目录标题 前言为什么需要动态每日生成一个密码&#xff1f;编写脚本定时任务java对应的代码 前言 社长最近接到一个需求&#xff0c;需要ftp每天动态生成一个密码 为什么需要动态每日生成一个密码&#xff1f; 在软硬件通讯过程中&#xff0c;就以共享单车为例&#xff0…

vsCode 忽略 文件上传

1 无 .gitignore 文件时&#xff0c;在项目文件右键&#xff0c;Git Bash 进入命令行 输入 touch .gitignore 生成gitignore文件 2 、在文件.gitignore里输入 node_modules/ dist/ 来自于&#xff1a;vscode git提交代码忽略node_modules_老妖zZ的博客-CSDN博客

深度学习_1_基本语法

数据结构 代码&#xff1a; import torchx torch.arange(12)##产生长度为12的一维张量print(x)##X x.resize(3, 4)##被弃用##print(X)y torch.reshape(x, (3, 4))##修改向量为矩阵&#xff0c;一维变二维print(y)print(y.size())xx torch.zeros((2, 3, 4))##三维矩阵&…

GEE:基于GLDAS数据集分析土壤湿度的时间序列变化

作者:CSDN @ _养乐多_ 本篇博客将介绍如何使用Google Earth Engine(GEE)进行土壤湿度数据的分析。我们将使用NASA GLDAS(Global Land Data Assimilation System)数据集,其中包括了关于土壤湿度的信息。通过该数据集,我们将了解土壤湿度在特定区域和时间段内的变化,并生…

Vue、js底层深入理解笔记(二)

1.跨域 跨域原因 > 浏览器的同源策略 属于一种保护机制 如果没有同源策略的保护 一般用来处理登录cookie、服务端验证通过后会在响应头加入Set-Cookie字段、下次再发请求的时候&#xff0c;浏览器会自动将cookie附加在HTTP请求的头字段Cookie中、也就是说跳转到其他网站你也…

Apache atlas 元数据管理治理平台使用和架构

1、前言 Apache Atlas 是托管于 Apache 旗下的一款元数据管理和治理的产品&#xff0c;目前在大数据领域应用颇为广泛&#xff0c;可以很好的帮助企业管理数据资产&#xff0c;并对这些资产进行分类和治理&#xff0c;为数据分析&#xff0c;数据治理提供高质量的元数据信息。…

企业电子招投标采购系统——功能模块功能描述+数字化采购管理 采购招投标

功能描述 1、门户管理&#xff1a;所有用户可在门户页面查看所有的公告信息及相关的通知信息。主要板块包含&#xff1a;招标公告、非招标公告、系统通知、政策法规。 2、立项管理&#xff1a;企业用户可对需要采购的项目进行立项申请&#xff0c;并提交审批&#xff0c;查看所…