一起用python做个炫酷音乐播放器,想听啥随便搜!【V2

self.tab_layout.addWidget(self.button_1236, 0, 3, 1, 1)

self.listwidget.doubleClicked.connect(lambda: self.change_func(self.listwidget))
self.listwidget.setContextMenuPolicy(Qt.CustomContextMenu)
self.listwidget.customContextMenuRequested[QPoint].connect(self.myListWidgetContext)
self.listwidget.setStyleSheet(self.css)
self.listwidget.setObjectName("listWidget")
self.tab_layout.addWidget(self.listwidget, 1, 0, 1, 4)
self.tabWidget.addTab(self.tab, " 搜索页 ")

self.tab2 = QWidget()
self.tab2.setObjectName("tab")
self.tab2_layout = QGridLayout()
self.tab2.setLayout(self.tab2_layout)
self.listwidget2 = QListWidget(self.tab2)
self.listwidget2.doubleClicked.connect(lambda: self.change_funcse(self.listwidget2))
self.listwidget2.setContextMenuPolicy(Qt.CustomContextMenu)
self.listwidget2.customContextMenuRequested[QPoint].connect(self.myListWidgetContext2)
self.listwidget2.setStyleSheet(self.css)
self.listwidget2.setObjectName("listWidget2")
self.listwidget2.setContextMenuPolicy(3)
self.tab2_layout.addWidget(self.listwidget2, 0, 0, 1, 1)
self.tabWidget.addTab(self.tab2, " 最近播放 ")
self.tab3 = QWidget()
self.tab3.setObjectName("tab")
self.tab3_layout = QGridLayout()
self.tab3.setLayout(self.tab3_layout)
self.label223 = QLabel(self)
# self.label5.setScaledContents(True)
pix_img = QPixmap(str(data + '/backdown.png'))
pix = pix_img.scaled(100, 100, Qt.KeepAspectRatio)
self.label223.setPixmap(pix)
# self.label5.setMaximumSize(1,1)
self.tab3_layout.addWidget(self.label223, 0, 0, 1, 1)
self.button_1237 = QPushButton(icon('fa.play', color='#FFFFFF', font=24), "播放全部")
self.button_1237.clicked.connect(self.allplaylove)
self.button_1237.setStyleSheet(
    '''QPushButton{background:#EC4141;border-radius:5px;}QPushButton:hover{background:#E92121;}''')
self.tab3_layout.addWidget(self.button_1237, 0, 1, 1, 1)
self.button_1235 = QPushButton(icon('fa.download', color='#D0D0D0', font=24), "下载全部")
self.button_1235.clicked.connect(self.downloadalllove)
self.button_1235.setStyleSheet(
    '''QPushButton{background:#222225;border-radius:5px;}QPushButton:hover{background:#303030;}''')
self.tab3_layout.addWidget(self.button_1235, 0, 2, 1, 1)
self.button_1236 = QPushButton(icon('fa.trash-o', color='#D0D0D0', font=24), "清空列表")
self.button_1236.clicked.connect(self.delove)
self.button_1236.setStyleSheet(
    '''QPushButton{background:#222225;border-radius:5px;}QPushButton:hover{background:#303030;}''')
self.tab3_layout.addWidget(self.button_1236, 0, 3, 1, 1)
self.listwidget3 = QListWidget(self.tab3)
self.listwidget3.doubleClicked.connect(lambda: self.change_funclove(self.listwidget3))
self.listwidget3.setContextMenuPolicy(Qt.CustomContextMenu)        self.listwidget3.customContextMenuRequested[QPoint].connect(self.myListWidgetContext3)
self.listwidget3.setStyleSheet(self.css)
self.listwidget3.setObjectName("listWidget3")
self.tab3_layout.addWidget(self.listwidget3, 1, 0, 1, 4)
self.tabWidget.addTab(self.tab3, " 喜爱的歌 ")
self.tab4 = QWidget()
self.tab4.setObjectName("tab")
self.tab4_layout = QGridLayout()
self.tab4.setLayout(self.tab4_layout)
self.listwidget4 = QListWidget(self.tab4)
# self.listwidget4.doubleClicked.connect(lambda: self.change\_func(self.listwidget))
self.listwidget4.setStyleSheet(self.css)
self.listwidget4.setObjectName("listWidget4")
self.tab4_layout.addWidget(self.listwidget4, 0, 0, 1, 1)
self.tabWidget.addTab(self.tab4, " 歌词 ")

self.tab5 = QWidget()
self.tab5.setObjectName("tab5")
self.tab5_layout = QGridLayout()
self.tab5.setLayout(self.tab5_layout)
self.listwidget5 = QListWidget(self.tab5)
self.listwidget5.doubleClicked.connect(lambda: self.change(self.listwidget5))
self.listwidget5.setContextMenuPolicy(Qt.CustomContextMenu)
self.listwidget5.customContextMenuRequested[QPoint].connect(self.myListWidgetContext5)
self.button_12351 = QPushButton(icon('fa.download', color='#D0D0D0', font=24), "添加目录")
self.button_12351.clicked.connect(self.add)
self.button_12351.setStyleSheet(
    '''QPushButton{background:#222225;border-radius:5px;}QPushButton:hover{background:#303030;}''')
self.tab5_layout.addWidget(self.button_12351, 0, 2, 1, 1)

self.button_12361 = QPushButton(icon('fa.trash-o', color='#D0D0D0', font=24), "清空列表")
self.button_12361.clicked.connect(self.dellocal)
self.button_12361.setStyleSheet(
    '''QPushButton{background:#222225;border-radius:5px;}QPushButton:hover{background:#303030;}''')
self.tab5_layout.addWidget(self.button_12361, 0, 3, 1, 1)
self.listwidget5.setStyleSheet(self.css)
self.listwidget5.setObjectName("listWidget5")
self.tab5_layout.addWidget(self.listwidget5, 1, 0, 1, 4)
self.tabWidget.addTab(self.tab5, " 本地歌曲 ")
self.right_layout.addWidget(self.tabWidget, 3, 0, 100, 90)

UI界面布局实现效果如下:  
 ![在这里插入图片描述](https://img-blog.csdnimg.cn/3135fb38e50e4805969743a836e7ce00.png?x-oss-process=image/watermark,type_ZHJvaWRzYW5zZmFsbGJhY2s,shadow_50,text_Q1NETiBARHJhZ29u5bCR5bm0,size_20,color_FFFFFF,t_70,g_se,x_16)


##### 2. 音乐本地下载及添加我喜爱的歌曲


我们根据V1.0版本完成的,**输入的关键字和选择音乐来源**进行音乐爬取,通过多线程,将歌曲、歌手、歌曲url地址全都获取;并将这些爬取的音乐数据列表显示到搜索页面中。双击列表页面中某一首歌曲,即可实现音乐播放功能。


V2.0版本中,我们添加了对当前播放音乐的本地下载、搜索页音乐列表一键下载、喜爱的歌列表一键下载、添加我喜爱的歌曲功能。


**音乐下载:**


对于音乐下载,我们可以进行当前播放音乐下载、搜索页音乐列表一键下载、喜爱的歌一键下载。如下图所示:![在这里插入图片描述](https://img-blog.csdnimg.cn/b9f339d9346f49029cd60cc2e5199630.png?x-oss-process=image/watermark,type_ZHJvaWRzYW5zZmFsbGJhY2s,shadow_50,text_Q1NETiBARHJhZ29u5bCR5bm0,size_20,color_FFFFFF,t_70,g_se,x_16)  
 核心代码如下:



当前播放音乐下载

def down(self):
if bo == ‘local’:
downpath = str(filew)
downpath = downpath.replace(‘/’, ‘\’)
downpath = downpath + SongName[num]
print(downpath)
print(‘explorer /select,{}’.format(downpath))
call(‘explorer /select,{}’.format(downpath))
else:
call(‘explorer /select,{}’.format(to))

下载所有音乐

def downloadall(self, typer):
try:
global typerr
typerr = typer
print(typer)
print(typerr)
self.work = downall()
self.work.start()
self.work.trigger.connect(self.disdownall)
except:
print(‘默认图片下载错误’)
pass

下载搜索页列表所有音乐

def downloadalls(self):
self.downloadall(‘boing’)

下载喜爱的歌列表所有音乐

def downloadalllove(self):
self.downloadall(‘love’)


**添加喜爱的歌:**


对于添加喜爱的歌曲,我们可以通过当前播放音乐的❤标志,也可以通过右键音乐列表进行喜爱的歌曲添加。核心代码如下:



通过点击❤标志,对当前播放音乐添加喜爱的歌

def lovesong(self):
if bo == ‘boing’ or bo == ‘boed’:
try:
global loves
global loveurls
global lovepics
global lovelrc
if bo == ‘boing’:
loves.append(songs[num])
loveurls.append(urls[num])
lovepics.append(pic[num])
lovelrc.append(lrcs[num])
elif bo == ‘boed’:
loves.append(songed[num])
loveurls.append(urled[num])
lovepics.append(picd[num])
lovelrc.append(lrcd[num])
else:
pass
except:
pass
self.work = firstThread()
self.work.start()
self.work.trigger.connect(self.dispng)
r = 0
self.listwidget3.clear()
for i in loves:
self.listwidget3.addItem(i)
self.listwidget3.item®.setForeground(Qt.white)
r = r + 1
print(loves)
else:
pass

通过右键音乐列表进行喜爱的歌曲添加

def addItem(self):
try:
global loves
global loveurls
global lovepics
global lovelrc
if list_confident == ‘boing’:
loves.append(songs[num_m])
loveurls.append(urls[num_m])
lovepics.append(pic[num_m])
lovelrc.append(lrcs[num_m])
else:
loves.append(songed[num_m])
loveurls.append(urled[num_m])
lovepics.append(picd[num_m])
lovelrc.append(lrcd[num_m])
self.work = firstThread()
self.work.start()
self.work.trigger.connect(self.dispng)
except:
pass
r = 0
self.listwidget3.clear()
for i in loves:
self.listwidget3.addItem(i)
self.listwidget3.item®.setForeground(Qt.white)
r = r + 1
print(‘done’)
print(loves)


这样我们就可以把歌曲添加到喜爱的歌子列表页面下,如下图所示。  
 ![在这里插入图片描述](https://img-blog.csdnimg.cn/095ecc38a70049aa9a6b6af8f22ec59d.png?x-oss-process=image/watermark,type_ZHJvaWRzYW5zZmFsbGJhY2s,shadow_50,text_Q1NETiBARHJhZ29u5bCR5bm0,size_20,color_FFFFFF,t_70,g_se,x_16)


##### 3. 喜爱的歌初始化读取显示及列表播放


对于添加到喜爱的歌曲列表,我们需要在退出音乐播放器程序时,将这些数据保存到本地文件,方便后面重新运行时初始化读取显示列表。


**喜爱歌曲本地保存:**  
 我们可以把喜爱的歌曲列表、喜爱歌曲图片、歌曲url链接、歌词等数据保存到本地。核心代码如下:



def close(self):
reply = QMessageBox.question(self, u’警告’, u’确定退出?', QMessageBox.Yes,
QMessageBox.No)
if reply == QMessageBox.Yes:
close = True
try:
mixer.music.stop()
except:
pass
try:
rmtree(str(data))
except Exception as e:
print(‘删除错误类型是’, e.class.name)
print(‘删除错误明细是’, e)
filepath = ‘{}/musicdata’.format(apdata)
try:
mkdir(filepath)
except:
pass
print(filepath)
with open(filepath + “/loves”, ‘w’, encoding=‘utf-8’) as f:
f.truncate(0)
print(f.write(str(loves)))
with open(filepath + “/lovepics”, ‘w’, encoding=‘utf-8’) as f:
f.truncate(0)
print(f.write(str(lovepics)))
with open(filepath + “/loveurls”, ‘w’, encoding=‘utf-8’) as f:
f.truncate(0)
print(f.write(str(loveurls)))
with open(filepath + “/lovelrc”, ‘w’, encoding=‘utf-8’) as f:
f.truncate(0)
print(f.write(str(lovelrc)))
with open(filepath + “/voice”, ‘w’, encoding=‘utf-8’) as f:
f.truncate(0)
print(f.write(str(voice)))
try:
rmtree(str(data))
except Exception as e:
print(‘删除错误类型是’, e.class.name)
print(‘删除错误明细是’, e)
exit()
else:
pass


**喜爱的歌初始化读取:**  
 重新运行音乐播放器时,我们需要加载保存在本地的喜爱歌曲数据,并将歌曲列表信息加载显示到喜爱的歌子列表页面中。核心代码如下:



def run(self):
try:
apdataas = getenv(“APPDATA”)
filepathas = ‘{}/musicdata’.format(apdataas)
global lovelrc
global loveurls
global loves
global lovepics
global voice
# 读取历史数据开始
try:
with open(filepathas + “/voice”, ‘r’, encoding=‘utf-8’) as f:
a = f.read()
# print(a)
voice = float(a)
print(voice)
self.trigger.emit(str(‘voicedone’))
except:
self.trigger.emit(str(‘voicedone’))
pass
with open(filepathas + “/loves”, ‘r’, encoding=‘utf-8’) as f:
a = f.read()
print(a)
strer = a
loves = literal_eval(strer)
with open(filepathas + “/lovepics”, ‘r’, encoding=‘utf-8’) as f:
a = f.read()
print(a)
strer = a
lovepics = literal_eval(strer)
with open(filepathas + “/loveurls”, ‘r’, encoding=‘utf-8’) as f:
a = f.read()
print(a)
strer = a
loveurls = literal_eval(strer)
with open(filepathas + “/lovelrc”, ‘r’, encoding=‘utf-8’) as f:
a = f.read()
print(a)
strer = a
lovelrc = literal_eval(strer)
self.trigger.emit(str(‘login’))
print(loves)
print(‘read finish’)
except:
print(‘read error’)
pass
# 读取数据结束

# 下载喜爱的歌列表中首项的歌曲封面
try:
    req = get(lovepics[0])
    checkfile = open(str(data + '/ls3.png'), 'w+b')
    for i in req.iter_content(100000):
        checkfile.write(i)

    checkfile.close()
    lsfile = str(data + '/ls3.png')
    safile = str(data + '/first.png')
    draw(lsfile, safile)
    self.trigger.emit(str('first'))
except:
    self.trigger.emit(str('nofirst'))
    pass    

**列表播放:**  
 对于加载的喜爱歌曲列表,我们可以对歌曲进行列表一键播放。



音乐播放

def bofang(self, num, bo):
print(‘尝试进行播放’)
try:
import urllib
global pause
global songs
global music
global downloading
downloading = True
self.console_button_3.setIcon(icon(‘fa.pause’, color=‘#F76677’, font=18))
pause = False
try:
mixer.stop()
except:
pass
mixer.init()
try:
self.Timer = QTimer()
self.Timer.start(500)
except:
pass
try:
self.label.setText(‘正在寻找文件…’)
self.work = WorkThread()
self.work.start()
self.work.trigger.connect(self.display)
except:
print(‘无法播放,歌曲下载错误’)
downloading = False
pass
except:
sleep(0.1)
print(‘播放系统错误’)
pass

播放所有歌曲

def playall(self, typer):
global num
global bo
try:
bo = typer
num = 0
self.bofang(bo, num)
except:
print(‘playall error’)
pass

播放喜爱歌曲

def allplaylove(self):
self.playall(‘love’)


##### 4. 歌词显示


对于播放的歌曲,我们可以进行歌词打印显示。核心代码如下:



def run(self):
if bo == ‘love’:
try:
proxies = {
‘http’: ‘http://124.72.109.183:8118’,
‘http’: ‘http://49.85.1.79:31666’

        }
        headers = {
            'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/86.0.4240.198 Safari/537.36',
            'X-Requested-With': 'XMLHttpRequest'}
        try:
            try:
                try:
                    aq = lovepics[num]
                    aqq = aq.split('/')
                except:
                    pass
                if type == 'kugou' and len(aqq) - 1 == 6:
                    aqqe = str(aqq[0]) + str('//') + str(aqq[2]) + str('/') + str(aqq[3]) + str('/') + str(
                        '400') + str('/') + str(aqq[5]) + str('/') + str(aqq[6])
                    print(aqqe)
                elif type == 'netease' and len(aqq) - 1 == 4:
                    aqn = aq.split('?')
                    b = '?param=500x500'
                    aqqe = (str(aqn[0]) + str(b))
                    print(aqqe)
                else:
                    aqqe = lovepics[num]
                req = get(aqqe)

                checkfile = open(str(data + '/ls1.png'), 'w+b')
                for i in req.iter_content(100000):
                    checkfile.write(i)

                checkfile.close()
                lsfile = str(data + '/ls1.png')
                safile = str(data + '/back.png')
                draw(lsfile, safile)
                picno = True
            except:
                print('图片错误')
                picno = False
                pass

            url1 = loveurls[num]
            print(url1)
            # os.makedirs('music', exist\_ok=True)
            number = number + 1
            path = str(data + '\{}.临时文件'.format(number))
            headers = {
                'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/121.110.430.128 Safari/537.36',
                'X-Requested-With': 'XMLHttpRequest'
            }
            with get(url1, stream=True, headers=headers) as r, open(path, 'wb') as file:
                total_size = int(r.headers['content-length'])
                content_size = 0
                for content in r.iter_content(chunk_size=1024):
                    if not stopdown:
                        file.write(content)
                        content_size += len(content)
                        plan = (content_size / total_size) \* 100
                        # print(int(plan))
                        develop = str(int(plan)) + str('%')
                        self.trigger.emit(str(develop))
                    else:
                        print ('down')
                        break
                    stopdown = False
            to = 'downloadmusic\{}.mp3'.format(songed[num])
            makedirs('downloadmusic', exist_ok=True)
        except:
            self.trigger.emit(str('nofinish'))
            pass
        try:
            lrct = []
            f = lovelrc[num]  # 按行读取
            # print(f)
            lines = f.split('\n')
            # print(lines)
            for i in lines:
                line1 = i.split('[')
                try:
                    line2 = line1[1].split(']')
                    if line2 == '':
                        pass
                    else:
                        linew = line2[1]
                        # print(linew)
                        lrct.append(linew)
                    self.trigger.emit(str('lrcfinish'))
                except:
                    print('歌词错误')
        except:
            pass
        try:
            copyfile(path, to)
        except:
            pass
        downloading = False
        self.trigger.emit(str('finish'))
    except:
        self.trigger.emit(str('nofinish'))  

效果如下所示:  
 ![在这里插入图片描述](https://img-blog.csdnimg.cn/b79c6688e9ac44cb85649c16795367f0.png?x-oss-process=image/watermark,type_ZHJvaWRzYW5zZmFsbGJhY2s,shadow_50,text_Q1NETiBARHJhZ29u5bCR5bm0,size_20,color_FFFFFF,t_70,g_se,x_16)


##### 5. 本地歌曲读取播放


**自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。**

**深知大多数Python工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!**

**因此收集整理了一份《2024年Python开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。**
![img](https://img-blog.csdnimg.cn/img_convert/5b2bd14b0897c159376fc36cf902454a.png)
![img](https://img-blog.csdnimg.cn/img_convert/e385ceae283129de7f98f656b8859cfa.png)
![](https://img-blog.csdnimg.cn/img_convert/46506ae54be168b93cf63939786134ca.png)
![](https://img-blog.csdnimg.cn/img_convert/252731a671c1fb70aad5355a2c5eeff0.png)
![](https://img-blog.csdnimg.cn/img_convert/6c361282296f86381401c05e862fe4e9.png) 
![](https://img-blog.csdnimg.cn/img_convert/9f49b566129f47b8a67243c1008edf79.png)

**既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Python开发知识点,真正体系化!**

**由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新**

**如果你觉得这些内容对你有帮助,可以添加V获取:vip1024c (备注Python)**
![img](https://img-blog.csdnimg.cn/img_convert/c7621c7f5b29e779409588348a00439a.png)



做了那么多年开发,自学了很多门编程语言,我很明白学习资源对于学一门新语言的重要性,这些年也收藏了不少的Python干货,对我来说这些东西确实已经用不到了,但对于准备自学Python的人来说,或许它就是一个宝藏,可以给你省去很多的时间和精力。



别在网上瞎学了,我最近也做了一些资源的更新,只要你是我的粉丝,这期福利你都可拿走。

我先来介绍一下这些东西怎么用,文末抱走。

* * *



**(1)Python所有方向的学习路线(新版)**

这是我花了几天的时间去把Python所有方向的技术点做的整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。



最近我才对这些路线做了一下新的更新,知识体系更全面了。



![在这里插入图片描述](https://img-blog.csdnimg.cn/8fc093dcfa1f476694c574db1242c05b.png)



**(2)Python学习视频**



包含了Python入门、爬虫、数据分析和web开发的学习视频,总共100多个,虽然没有那么全面,但是对于入门来说是没问题的,学完这些之后,你可以按照我上面的学习路线去网上找其他的知识资源进行进阶。



![在这里插入图片描述](https://img-blog.csdnimg.cn/d66e3ad5592f4cdcb197de0dc0438ec5.png#pic_center)



**(3)100多个练手项目**

我们在看视频学习的时候,不能光动眼动脑不动手,比较科学的学习方法是在理解之后运用它们,这时候练手项目就很适合了,只是里面的项目比较多,水平也是参差不齐,大家可以挑自己能做的项目去练练。



![在这里插入图片描述](https://img-blog.csdnimg.cn/f5aeb4050ab547cf90b1a028d1aacb1d.png#pic_center)



**(4)200多本电子书**  

  

这些年我也收藏了很多电子书,大概200多本,有时候带实体书不方便的话,我就会去打开电子书看看,书籍可不一定比视频教程差,尤其是权威的技术书籍。



基本上主流的和经典的都有,这里我就不放图了,版权问题,个人看看是没有问题的。



**(5)Python知识点汇总**

知识点汇总有点像学习路线,但与学习路线不同的点就在于,知识点汇总更为细致,里面包含了对具体知识点的简单说明,而我们的学习路线则更为抽象和简单,只是为了方便大家只是某个领域你应该学习哪些技术栈。



![在这里插入图片描述](https://img-blog.csdnimg.cn/c741a91b05a542ba9dc8abf2f2f4b1af.png)



**(6)其他资料**



还有其他的一些东西,比如说我自己出的Python入门图文类教程,没有电脑的时候用手机也可以学习知识,学会了理论之后再去敲代码实践验证,还有Python中文版的库资料、MySQL和HTML标签大全等等,这些都是可以送给粉丝们的东西。



![在这里插入图片描述](https://img-blog.csdnimg.cn/9fa77af248b84885a6ec779b2ead064d.png)

**这些都不是什么非常值钱的东西,但对于没有资源或者资源不是很好的学习者来说确实很不错,你要是用得到的话都可以直接抱走,关注过我的人都知道,这些都是可以拿到的。**




**一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**
![img](https://img-blog.csdnimg.cn/img_convert/25e4ff80afb20e287bb8064d96cacc4b.png)

总有点像学习路线,但与学习路线不同的点就在于,知识点汇总更为细致,里面包含了对具体知识点的简单说明,而我们的学习路线则更为抽象和简单,只是为了方便大家只是某个领域你应该学习哪些技术栈。



![在这里插入图片描述](https://img-blog.csdnimg.cn/c741a91b05a542ba9dc8abf2f2f4b1af.png)



**(6)其他资料**



还有其他的一些东西,比如说我自己出的Python入门图文类教程,没有电脑的时候用手机也可以学习知识,学会了理论之后再去敲代码实践验证,还有Python中文版的库资料、MySQL和HTML标签大全等等,这些都是可以送给粉丝们的东西。



![在这里插入图片描述](https://img-blog.csdnimg.cn/9fa77af248b84885a6ec779b2ead064d.png)

**这些都不是什么非常值钱的东西,但对于没有资源或者资源不是很好的学习者来说确实很不错,你要是用得到的话都可以直接抱走,关注过我的人都知道,这些都是可以拿到的。**




**一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**
[外链图片转存中...(img-6rch8WF0-1712882837176)]

  • 3
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,下面是一个简单的音乐播放器Python代码示例: ```python import os import pygame # 初始化Pygame pygame.init() # 播放器类 class MusicPlayer: def __init__(self): # 播放器状态 self.playing = False # 歌曲列表 self.songs = [] # 当前歌曲索引 self.current_song_index = 0 # 创建Pygame音乐播放器 pygame.mixer.init() # 添加歌曲 def add_song(self, file_path): # 获取文件名 file_name = os.path.basename(file_path) # 添加到歌曲列表 self.songs.append({'file_path': file_path, 'file_name': file_name}) # 播放歌曲 def play_song(self, index): # 加载歌曲文件 file_path = self.songs[index]['file_path'] pygame.mixer.music.load(file_path) # 播放歌曲 pygame.mixer.music.play() # 更新播放器状态 self.playing = True self.current_song_index = index # 暂停歌曲 def pause_song(self): pygame.mixer.music.pause() self.playing = False # 继续播放歌曲 def unpause_song(self): pygame.mixer.music.unpause() self.playing = True # 停止歌曲 def stop_song(self): pygame.mixer.music.stop() self.playing = False # 上一首歌曲 def prev_song(self): if self.current_song_index > 0: self.stop_song() self.play_song(self.current_song_index - 1) # 下一首歌曲 def next_song(self): if self.current_song_index < len(self.songs) - 1: self.stop_song() self.play_song(self.current_song_index + 1) # 测试代码 if __name__ == '__main__': # 创建播放器实例 player = MusicPlayer() # 添加歌曲 player.add_song('song1.mp3') player.add_song('song2.mp3') player.add_song('song3.mp3') # 播放歌曲 player.play_song(0) # 暂停歌曲 player.pause_song() # 继续播放歌曲 player.unpause_song() # 上一首歌曲 player.prev_song() # 下一首歌曲 player.next_song() ``` 以上代码仅为演示用途,实际应用中需要对界面、播放列表、播放器状态等方面进行更加细致的设计和实现。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值