第一次编程作业(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="width:60px;vertical-align:middle;margin-right:10px;" />
    
      		<div class="" style="display:inline-block;vertical-align:middle;">
      			<div style="width: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="width: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分钟
posted @ 2020-09-12 10:14  xdt  阅读(424)  评论(3编辑  收藏  举报