zoukankan      html  css  js  c++  java
  • 第一次编程作业(My Own Score)

    博客班级 https://edu.cnblogs.com/campus/fzzcxy/2018SE2
    作业要求 https://edu.cnblogs.com/campus/fzzcxy/2018SE2/homework/11169
    作业目标 <爬取网页内容、学会使用Git、记录编程过程>
    作业源代码 https://gitee.com/xie-daotong/personal
    学号 <211806352>
    1. 需求分析:

      从网页中获取属于自己的经验值,利用 java 编程和已知的成绩算法实现计算自己的期末成绩,最后上传源码至码云。

    2. 思路分析:

      分为三大块来进行。

      • 解析保存到本地的网页并获取相对应的经验值数据

      • 成绩计算:读取配置文件中的经验值,用成绩算法(个人获得的经验值总分 / 应得经验值总分 * 100)计算所得成绩

      • 利用 Git 上传源码到远程仓库

      分为三大块的优势在于这样理清了整个编程逻辑,可以分模块完成,若遇到自己不能解决的问题也能够分步学习,提高了编程的效率。

    3. 编程过程:

      • 首先要解析网页,在度娘的帮助下我知道了要用到 Jsoup 来解析网页内容,所以第一步要导入 Jsoup 的 jar 包。(这个过程我又一次巩固了如何导包)

      那么该如何利用 Jsoup 解析网页呢?

      要利用到下面这段代码:

      File Html = new File("文件目录");
      Document source = Jsoup.parse(文件名, "UTF-8", "未找到文件替换的URL");
      

      这样 source 里现在存的就是整个网页的源代码

      • 接下来获取相应部分的经验值:根据解析的源代码,利用 Jsoup 强大的选择器找出所要的经验值。

      我在这里举如何获取课前自测部分的经验为例,其他部分大同小异

      <div class="interaction-rows">
        	<div class="interaction-row" data-appraise-type="" data-appraiser-id="" data-type="QUIZ" data-show='show'
        	 data-row-status="END" data-id="EAB1BCA6-A538-F2B4-CE47-D83D44F9EEC9" data-url="https://www.mosoteach.cn/web/index.php?                              c=interaction_quiz&m=quiz_ranking&clazz_course_id=CD7AE281-4AF8-11EA-9C7F-98039B1848C6&id=EAB1BCA6-A538-F2B4-CE47-D83D44F9EEC9&order_item=group&status=">
        		<img src="https://static-cdn-oss.mosoteach.cn/mosoteach2/common/images/activities-list-icon-testing.png" alt=""
        		 style="60px;vertical-align:middle;margin-right:10px;" />
      
        		<div class="" style="display:inline-block;vertical-align:middle;">
        			<div style="822px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;">
        				<span class="interaction-status end">已结束</span>
        				<span class="interaction-name grey fontsize-14 color-33" title="2020-04-02课前自测:复习文件管理">
        					2020-04-02课前自测:复习文件管理 </span>
        			</div>
        			<div class="clear20"></div>
        			<div class="" style="822px;">
        				<div class="" style="float:left;">
        					<span>共</span>
        					<span>5</span>
        					<span>道题目</span>
        					<span style="margin:0 5px;">|</span>
        					<span>共 </span>
        					<span>56</span>
        					<span>
        						人作答 </span>
        					<span style="margin:0 5px;">|</span>
        					<span>2020-04-02</span>
        					<span style="margin:0 5px;">|</span>
        					<!-- 经验值 START -->
        					<!-- 其他活动 -->
        					<span style="color:#8FC31F;">3 经验</span>
        					<!-- 经验值 END -->
        					<!-- 剩余时间 -->
        				</div>
        				<div class="clear"></div>
        			</div>
        		</div>
        	</div>
      

      放出课前自测部分的源代码,我们想获得其中的经验值,最开始的工作就是要定位这个块

      那么该如何定位呢?(方法不止一种,我的仅作示例)

      仔细的同学不难看出,源代码开头部分

      //课前自测部分:
      <div class="interaction-row" data-appraise-type="" data-appraiser-id="" data-type="QUIZ" data-show='show'
      data-row-status="END"
      
      //编程题部分:
      <div class="interaction-row"  data-appraise-type="TEACHER" data-appraiser-id=""
      data-type="HOMEWORK" data-show='show' data-row-status="END"
      

      观察上面两部分的代码块,不难发现,课前自测部分我们可以用

      data-type="QUIZ"
      

      这个属性值来进行定

      而编程题则用

      data-appraise-type="TEACHER"
      

      来进行定位,当然,每个人看到的区别都不一样,选自己觉得最简单的那个方法就OK。我选这个是因为除了编程题和附加题外,其他部分的 data-appraise-type 属性都是不同的。

      知道了定位方法后肯定要实现出来,上代码

      Elements beforeParent = sourceSmall.select("[data-type=QUIZ]");
      // sourceSmall 为我们从小班课里解析的源码,调用方法 select 即可定位到属性值符合的 div 块,非常的方便。
      

      定位完成,看下图,我现在定位到的是红圈圈位置。绿圈是我们要定位的最终位置,每个颜色代表每一级。我们可以用到 child() 方法来进行定位下级。

      图片
      按图示,此段代码应为

      beforeParent.child(1)//第二个蓝圈位置
      .child(2)//第二个粉圈位置
      .child(0)//第一个黑圈位置
      .child(10)//绿圈位置
      

      很好理解对吧,经验值得获取到这里已经基本完成。

      我们考虑到

      data-appraise-type="TEACHER"//这个属性并不唯一,故需要利用循环将相同部分的经验值相加
      
      //循环代码
      for (int i = 0; i < beforeParent.size(); i++) { //利用获取的条数作为循环次数
      Element beforeSmall= beforeParent.get(i).select("div").first().child(1).child(2).child(0).child(10);//获取经验值数据的定位
      String beforeScore =  beforeSmall.text().replaceAll(" 经验", "");//获取的数据中有字符串,要过滤
      float before = Float.parseFloat(beforeScore);//经验值在这之前位字符串,要转为浮点型
      beforeSum += before;//经验值求和
        }
      

      这样就完成了课前自测的经验值总分。其他部分类似,有些要加判断,例如是否已参与作为经验值相加的条件。

      • 获取配置中的经验值总分

      要利用到 Properties 类 ,如何使用? 代码如下

      class myProperties {
      public static void main(String[] args) throws Exception {
        Properties pps = new Properties();
        pps.load(new FileInputStream("file.properties"));//加载文件
        Enumeration fileName = pps.propertyNames();
        while (fileName.hasMoreElements()) { //判断元素
            String strKey = (String) fileName.nextElement(); //获取关键字
            String strValue = pps.getProperty(strKey); //获取关键字对应的值
            System.out.println(strKey + "," + strValue);
                          }
                      }
                  }
      

      网页链接如何读取配置文件

      • 最后按照权重和比例计算成绩即可

    4.git到远程仓库

      * 在码云创建仓库。
    
      * 在本地创建仓库
    
      * git 配置远程仓库
    
      * git clone 远程仓库到本地
    
      * 进入与远程仓库同名的文件夹,右键 git base here
    
      * 将要上传的文件拖入文件夹中
    
      * 开始上传,利用以下代码
    
      git add .
      git commit -m"备注"
      git push
    
     * 最后输入码云账号密码即可
    

    5.作业总结:

      主要学会了 Jsoup 的使用,爬取网页内容的大概方式,读取配置文件,从本地仓库上传文件至远程仓库。
    

    6.还未解决的问题:

      代码冗余严重,使用CMD命令行无法运行程序,待优化。
    

    7.作业实际完成时间

    估计 实际
    代码行数 ---- 272
    思路 15分钟 30分钟
    理出逻辑 40分钟 60分钟
    编程 120分钟 180分钟
    测试 10分钟 20分钟
    博客 100分钟 120分钟
    总计 275分钟 390分钟
  • 相关阅读:
    Linux系统操作问题汇总
    记录一些mysql数据库常用操作命令和问题汇总
    python学习之路-练习小程序02(模拟用户登录)
    python学习之路02(基础篇2)
    python学习之路-练习小程序01(猜年龄)
    python学习之路01(基础篇1)
    hashmap详解(基于jdk1.8)
    maven创建项目太慢怎么办
    CAS原理
    JUC原子类3-AtomicLongArray原子类
  • 原文地址:https://www.cnblogs.com/211806352xiedaotong/p/13649196.html
Copyright © 2011-2022 走看看