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

wordpress 积分购物北京网站优化哪家好

wordpress 积分购物,北京网站优化哪家好,政府网站模板修改,网站里面的数据库是怎么做的博主介绍:专注于Java .net php phython 小程序 等诸多技术领域和毕业项目实战、企业信息化系统建设,从业十五余年开发设计教学工作 ☆☆☆ 精彩专栏推荐订阅☆☆☆☆☆不然下次找不到哟 我的博客空间发布了1000毕设题目 方便大家学习使用 感兴趣的可以…


博主介绍:专注于Java .net  php phython  小程序 等诸多技术领域和毕业项目实战、企业信息化系统建设,从业十五余年开发设计教学工作

☆☆☆ 精彩专栏推荐订阅☆☆☆☆☆不然下次找不到哟
我的博客空间发布了1000+毕设题目 方便大家学习使用
感兴趣的可以先收藏起来,还有大家在毕设选题,项目以及论文编写等相关问题都可以给我留言咨询,希望帮助更多的人

🍅文末获取源码联系🍅

本个性化音乐推荐平台的开发利用Idea作为本系统的开发工具,MySQL数据库作为开发的数据库系统页面展现jsp技术展现,采用框架springboot做为开发主要框架。系统分为前台和后台功能,前台主要是用户进行业务操作,后台管理功能,主要是管理员。后台主要主要分为用户管理、标签管理、音乐分类管理、音乐管理、浏览管理、收藏管理、帖子管理、回复管理、关联规则管理等。前台的功能主要的功能有用户注册、登录、个人信息修改、音乐浏览、音乐分类浏览、音乐推荐(采用关联规则算法结合用户访问音乐的基础数据为依据进行推荐),在线发帖、回帖等。对于音乐数据系统系统采用python对相关网页音乐(免费,非收费)进行爬取本地化存储

系统主要功能包括:管理员登录、用户管理、标签管理、音乐分类管理、音乐管理、浏览管理、收藏管理、帖子管理、回复管理、关联规则管理、个人信息。系统中管理员主要是为了安全有效地储存和管理各类信息,并且对后台有相应的操作权限。

  1. 系统功能

前台主要功能:

  1. 用户注册、登录,登录时选择当天的心情。记录到session值方便系统根据心情推荐音乐
  2. 音乐分类浏览
  3. 访问音乐详情时,系统根据关联规则算法推荐音乐信息,同时记录用户浏览记录,收藏音乐信息等
  4. 查看浏览音乐记录信息,收藏音乐信息
  5. 发帖,回帖等基础功能
  6. 在线播放音乐收听
  7. 个人信息修改

后台主要功能:

(1)人员信息:对人员信息进行维护。

(2)标签信息:对标签信息进行增加、列表展现、修改、删除等。

(3)分类信息:对音乐分类信息进行增加、列表展现、修改、删除等。

(4)音乐信息管理:对音乐信息进行增加、列表展现、修改、删除等。

(5)浏览信息管理:对音乐浏览信息进行列表展现、删除等。

(6)收藏信息管理:对音乐收藏信息进行列表展现、删除等。

(7)帖子信息管理:对帖子信息进行列表展现、删除等。

(8)帖子回复信息管理:对帖子回复信息进行列表展现、删除等。

(9)关联规则信息管理:对关联规则配置维护。

(10)个人信息修改

Python爬取音乐网站

  1. 通过pycharm平台利用python爬取固定的音乐(可爬取)信息展示列表
  2. 爬取每个音乐信息把对应基本信息存入到数据库中,同时文件存储到磁盘
  3. 对于同名文件系统去重防止存入同名文件造成数据冗余

     顶层数据流图分析 

    主要包括两个角色,用户和管理员进行相关业务操作,如图所示:

  4.  

     一层数据流图分析 

    通过一层数据流图分析,用户和管理员对应操作的数据流关系,如图所示:

  5. 系统主要包括11个大类模块,包含管管理员信息类,用户信息类,公告信息类,标签信息类,分类信息类,音乐信息类,浏览信息类,收藏信息类,帖子信息类,回复信息类,关联规则信息类等,具体如图所示:

  6. 个性化音乐推荐平台主要实现音乐信息的一体化信息管理,涉及到了管理员实体,用户实体,公告实体,标签实体,分类实体,音乐实体,浏览实体,收藏实体,帖子实体,回复实体,关联规则实体等多个实体。下面简单介绍几个关键的实体E-R图。

    (1)个性化音乐推荐平台的E-R图,见图4-2。

    5.2.1 系统首页界面

    访问音乐首页面如图5-1所示:

  7. 图5-1 系统首页登陆界面

    5.2.2 查看歌曲模块

    查看歌曲界面,首先展现歌曲信息,同时根据个性化推荐音乐。系统采用两种模式综合设计推荐音乐功能,登录系统的时候的用户不仅仅输入用户名和密码,同时让用户选择现在的心情,心情属于标签中维护的内容,每个音乐都有一个标签属性,就是对应的心情。当系统关联规则推荐算法的数据采集不够,或者计算不出来数据的情况下,用户访问一个音乐的时候,系统根据用户登录的时候选择心情,随机推荐这个心情下的一个音乐。

    当系统用户 登录后访问每个音乐信息的时,系统记录用户访问音乐日志信息,这个也是关联规则算法的计算的基础数据依据。当用户访问一个音乐信息的时候,系统通过关联规则算法结果表读取,通过后台计算用户访问音乐的行为数据信息,得到推荐出最有可能访问其他音乐信息,然后推荐出来。如图5-2所示。

    图5-2 歌曲信息界面

        系统采用关联规则算法,基于用户浏览数据进行计算,如图所示:

    核心算法代码:

    sc.forEach(set->{

                List<Set<String>> subset = nonEmptySubset(set);

                int y=support(set,data);

                double support = 1.0*y/data.size();

                subset.forEach(sub->{

                    int x=support(sub,data);

                    HashSet<String> target = new HashSet<String>(set);

                    target.removeAll(sub);

                    double conf = 1.0*y/x;

                    System.out.println(set+"\t"+sub+"-->"+target+

                            "\t"+y+"/"+x+"("+String.format("%.2f", conf)+")\t"+

                            y+"/"+data.size()+"("+String.format("%.2f", support)+

                            ")\t"+(conf>this.confidence));

                    Map mp=new HashMap();

                    System.out.println("id="+id);

                    String targeta=this.makeString(String.valueOf(target)).trim();

                    System.out.println("String.valueOf(sub).trim()=="+targeta);

                    if(!id.equals("")) {

                        if (id.equals(targeta)) {

                            System.out.println("ok in ");

                            mp.put("sub", this.makeString(String.valueOf(sub)));

                            mp.put("target", this.makeString(String.valueOf(target)));

                            mp.put("conf", String.format("%.2f", conf));

                            mp.put("support", String.format("%.2f", support));

                            list.add(mp);

                        }

                    }

    //                }else{

    //                    mp.put("sub", this.makeString(String.valueOf(sub)));

    //                    mp.put("target", this.makeString(String.valueOf(target)));

    //                    mp.put("conf", String.format("%.2f", conf));

    //                    mp.put("support", String.format("%.2f", support));

    //

    //                }

                });

            });

            return list;

        }

        //计算频繁项目集的支持度

        public Integer support(Set<String> set,List<Set<String>> data){

            return  (int) data.stream()

                    .filter(d->d.containsAll(set))

                    .count();

        }

        //生成候选项集

        //安算法来讲应该是将候选项集按一定规则排序 将两个集合只有最后一个元素不同的合并

        //个人理解:

        //对任意频繁集A B属于S  若  C = A 并 B 是频繁的  则  D=C- (A 交  B) 也是频繁的

        public  List<Set<String>> candidateSet(List<Set<String>> list) {//候选项集

            List<Set<String>> candidate=new ArrayList<Set<String>>();

            for(int i=0;i<list.size();i++) {

                for(int j=i+1;j<list.size();j++) {

                    Set<String> item = list.get(i);

                    Set<String> compare = list.get(j);

                    if(item.size()==1){

                        Set<String> unionn=new HashSet<String>(item);

                        unionn.addAll(compare);

                        candidate.add(unionn);

                    }else{

                        Set<String> intersection=new HashSet<String>(item);

                        intersection.retainAll(compare);

                        if(!intersection.isEmpty()) {

                            Set<String> unionn=new HashSet<String>(item);

                            unionn.addAll(compare);

                            Set<String> difference =new HashSet<String>(unionn);

                            difference.removeAll(intersection);

                            if(allFrequentSet.contains(difference)) {

                                candidate.add(unionn);

                            }

                        }

                    }

                }

            }

            candidate = candidate.stream().distinct().collect(Collectors.toList());

            return candidate;

        }

        //扫描满足最小支持度的频繁项目集

        public  List<Set<String>> scan(Map<Set<String>, Integer> frequent,double minSupport) {

            List<Set<String>> list=new ArrayList<Set<String>>();

            for(Set<String> key :frequent.keySet()) {

                if(frequent.get(key)>=minSupport*data.size()) {

                    list.add(key);

                    allFrequentSet.add(key);

                }

            }

            return list;

        }

    5.2.3 公告管理模块

    点击公告管理菜单,显示添加公告信息和公告信息列表界面,点击添加公告信息,右侧界面呈现出添加的公告信息界面,包括公告公告编号,标题,内容,发布时间等信息,添加公告信息完毕点击“提交”按钮,则添加公告信息成功。点击“公告列表”,右侧界面呈现出需要公告的具体信息,包括公告编号,标题,内容,发布时间等信息,可对逐条公告信息进行查看、删除和修改,如图5-3所示。

    图5-3 公告管理界面


  8. 大家点赞、收藏、关注、评论啦 ,需要源码 其他的定制服务  下方联系卡片↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓ 或者私信作者

http://www.dt0577.cn/news/1935.html

相关文章:

  • 成都网站建设名录bt磁力搜索引擎索引
  • 完善wordpressseo的目的是什么
  • hge网站做微端凡科网站官网
  • wordpress新建php页面模板seo优化技术培训
  • 淄博网站建设至信网络在线代理浏览网页
  • 优质的天津网站建设网络营销带来的效果
  • 成都游戏开发网站关键词优化排名软件
  • 汕头 做网站深圳推广优化公司
  • wordpress word文档360网站关键词排名优化
  • 内江住房和城乡建设厅网站网络营销的四大要素
  • 网站视频插件怎么做佛山网站建设工作
  • 拿品牌做网站算侵权吗优化设计答案五年级下册
  • 宿迁网站建设介绍公司今日预测足球比分预测
  • 世界服装鞋帽网免费做网站企业网站优化解决方案
  • 微网站如何做微信支付宝支付宝支付接口网络营销推广平台有哪些
  • 淮北刚刚发生的事山东seo
  • 老会计手把手教做帐官方网站seo短视频网页入口引流网站
  • 做博彩网站的虚拟空间免费网站seo排名优化
  • 腾讯企业邮箱忘记密码廊坊快速优化排名
  • 外围网站代理怎么做企业培训平台
  • 本科生做网站编辑还有哪些平台能免费营销产品
  • 做网站要收订金吗如何建网站要什么条件
  • 用vue做的网站怎么实现响应式网络培训研修总结
  • 做网站要不要35类商标广告策划书
  • 免费网站推广文章免费建站模板
  • 天津武清做网站广州网站到首页排名
  • 外贸网站做的作用是什么新郑网络推广外包
  • 广州网站建设企业上海培训机构排名榜
  • 网站外部链接做多少合适呢搜索引擎调词工具
  • 大型网站制作女教师遭网课入侵直播录屏曝光i