当前位置: 首页 > wzjs >正文

南京建设交易中心网站北京网站设计权威乐云践新

南京建设交易中心网站,北京网站设计权威乐云践新,深圳市宝安区松岗街道邮政编码,建营销网站Python练习:读取Apple Plist文件 Plist文件简介 ​​定义​​:Apple公司创建的基于XML结构的文件格式​​特点​​:采用XML语法组织数据,可存储键值对、数组等结构化信息文件扩展名​​:.plist应用场景: ​​iOS系统:​…

Python练习:读取Apple Plist文件

Plist文件简介

  1. ​​定义​​:Apple公司创建的基于XML结构的文件格式
  2. ​​特点​​:采用XML语法组织数据,可存储键值对、数组等结构化信息
  3. 文件扩展名​​:.plist
  4. 应用场景:
    ​​iOS系统:​​ 应用描述文件(权限配置:蓝牙/网络访问/GameCenter等)IPA安装包中的配置信息 ​​
    macOS系统​​: .app应用的配置文件 系统偏好设置存储 ​​
    苹果生态​​ iTunes音乐播放列表 Xcode项目配置

Python操作库:plistlib

import plistlib

代码适配指南(Python 2 → Python 3)
​​废弃方法​​(Python 2旧版)

plist = plistlib.read(filename)

​​正确方法​​(Python 3新版)

with open(filename, 'rb') as plist_file:plist = plistlib.load(plist_file)

注意事项

  1. 始终使用​​二进制模式​​(‘rb’)打开文件 Python
  2. 3.4+ 支持load()/dump()替代旧版API
  3. macOS内置plutil工具可验证文件有效性:bash 下运行下面的代码
    plutil -lint Example.plist

下文是练习代码,其中也包含了画图部分
练习代码:

import re, argparse
import sys
from matplotlib import pyplot
import plistlib
import numpy as np# 找到重复的音乐
def find_duplicates(file_name):print("Find duplicate tracks in %s..." % file_name)with open(file_name, 'rb') as f:plist = plistlib.load(f)# 读取playlist# 获取音轨目录tracks = plist['Tracks']# 创建音轨字典track_names = {}# 结构:{name:(duration,count)}# 遍历 添加for track_id, track in tracks.items():try:name = track['name']duration = track['Total Time']# 检查是不是以及在在字典里面了if name in track_names:# 匹配 歌曲名称和时长if duration // 1000 == track_names['name'][0] // 1000:count = track_names[name][1]track_names[name] = (duration, count + 1)else:# 不匹配的情况下track_names[name] = (duration, count)except:# ignorepass# 保存重复的音轨, name, countdups = []for k, v in track_names.items():if v[1] > 1:dups.append(k, v[1])# 保存到一个文件if len(dups) > 0:print("发现一共有%d个重复的文件, 以及保存到了dup.txt中" % len(dups))else:print("没有发现任何重复的文件")f = open("dups.txt", "w")for val in dups:f.writable("[%d] %s \n" % (val[0], val[1]))f.close()# 查找多个播放列表中的共同的音轨
def find_common_tracks(file_names):# a list of sets of track namestrack_name_sets = []# 遍历读取多个plist文件for file_name in file_names:track_names = set()with open(file_name, 'rb') as f:plist = plistlib.load(f)# 获取音轨节点tracks = plist.get("Tracks", {})# 遍历迭代for track_id, track in tracks.items():try:track_names.add(track['Name'])except:# ignorepass# 添加到track_name_sets中track_name_sets.append(track_names)# 交集处理common_tracks = set.intersection(*track_name_sets)# 写文件if len(common_tracks) > 0:f = open("common.txt", "w")for val in common_tracks:# s = "%s\n" % valf.write(f"{val}\n")f.close()print(f"Track names wirte to common.txt { len(common_tracks)}")else:print("No common tracks!")# 收集歌曲评分和时长
def plot_stats(file_name):# 读取播放列表with open(file_name, 'rb') as f:plist = plistlib.load(f)tracks = plist['Tracks']# 创建音轨排序和时长ratings = []durations = []for track_id, track in tracks.items():try:ratings.append(track['Album Rating'])durations.append(track['Total Time'])except:# ignorepass# 确保是有效数据if ratings == [] or durations == []:print(f"在文件中%s没有有效的Album Rating/Total Time  数据 {file_name}")return# scatter plot x= np.array(durations, np.int32) # convert to minutes x = x/60000.0 y = np.array(ratings, np.int32) pyplot.subplot(2, 1, 1) pyplot.plot(x, y, 'o') pyplot.axis([0, 1.05*np.max(x), -1, 110]) pyplot.xlabel('Track duration') pyplot.ylabel('Track rating') # plot histogram pyplot.subplot(2, 1, 2) pyplot.hist(x, bins=20) pyplot.xlabel('Track duration') pyplot.ylabel('Count') # show plot pyplot.show() def main():# create parserdescStr = """This program analyzes playlist files (.xml) exported from iTunes."""parser = argparse.ArgumentParser(description=descStr)# add a mutually exclusive group of argumentsgroup = parser.add_mutually_exclusive_group()# add expected argumentsgroup.add_argument('--common', nargs = '*', dest='plFiles', required=False)group.add_argument('--stats', dest='plFile', required=False)group.add_argument('--dup', dest='plFileD', required=False)# parse argsargs = parser.parse_args()if args.plFiles:# find common tracksfind_common_tracks(args.plFiles)elif args.plFile:# plot statsplot_stats(args.plFile)elif args.plFileD:# find duplicate tracksfind_duplicates(args.plFileD)else:print("These are not the tracks you are looking for.")if __name__ == "__main__":main()

最后这个是画图的部分,以后有兴趣再研究吧
在这里插入图片描述

http://www.dtcms.com/wzjs/548058.html

相关文章:

  • 站内优化怎么做我想给别人做网站
  • 金融 网站建设南昌网站建设方案维护
  • 伊川网站开发南山商城网站建设哪家便宜
  • 网站首页结构图建在线教育网站需要多少钱
  • 个人备案 什么网站茌平网站建设菜谱制作
  • 建com网站近年网络营销成功案例
  • 音乐网站建设报告网站自助授权系统
  • 局网站建设管理制度文化馆为何需要建设自己的网站
  • 免费网站模板库怎么做钓鱼网站生成器
  • 网站怎么做移动适配山东平台网站建设平台
  • 上海网站设计培训班网页游戏网站链接
  • 鞋网站建设方案wordpress公共函数在哪
  • 免费中文网站模板下载wordpress 目录权限管理
  • 建个小型网站服务器网站设计的工具
  • 想自己做网站怎么做实名制认证网站
  • 网站建设兼职做篮球网站用的背景图片
  • 怎么做推广赚钱百度关键词快速优化
  • 最好网站建设制作是那个广州外贸建网站
  • 企业类网站模版成都食品网站开发
  • 可以充值的网站怎么建设经三路专业做网站
  • 高端网站设计新感觉建站优化课程
  • 让你做一个旅游网站你会怎么做工作室名字创意好听
  • 网页设计实训总结意义报告漳州网站优化
  • 乐度网上购物网站建设方案中国建筑网信息查询
  • 购物网站图片的放大怎么做的win淘宝客wordpress主题模板
  • 企业网站建设飞沐网站建设推进情况
  • 新乡专业做网站多少钱网站开发需求分析与功能设计
  • 网站返回按钮设计网站建设后台管理便捷
  • 哪些是个人网站贵州网站seo
  • 商城网站开发报价seo网站推广优化公司