| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 2400 人关注过本帖
标题:如何统计每位老师每周上课节数
只看楼主 加入收藏
王咸美
Rank: 1
等 级:新手上路
帖 子:658
专家分:3
注 册:2018-1-4
结帖率:97.44%
收藏
已结贴  问题点数:20 回复次数:8 
如何统计每位老师每周上课节数
如何统计每位老师每周上课节数
如何根据教师名单jsmd.dbf、学校日课总表rkzb201803.dbf和教师仼课表jsrkb.dbf自动统计出每位教师每周课时数,并生成到word文档打印输出,望高手不吝赐教,万分感谢!!!
scgrkb.rar (46.15 KB)
搜索更多相关主题的帖子: 教师 统计 打印 dbf 老师 
2020-03-20 09:25
王咸美
Rank: 1
等 级:新手上路
帖 子:658
专家分:3
注 册:2018-1-4
收藏
得分:0 
如何修改下列代码,统计每位教师每周上课节数,并保存到word文档打印输出。


 SET TALK OFF
 SET SAFETY OFF
 CLOSE ALL
 CLEAR

 wjm=SYS(5)+SYS(2003)+"\grkbmb.doc"
 WordApp=CREATEOBJECT("Word.application")

 USE jsmd ALIAS jsmd IN 0
 USE jsrkb ALIAS jsrkb IN 0
 USE rkzb201803 ALIAS rkzb201803 IN 0

 SELECT jsmd
 GOTO top
 rkmc=""
 SCAN
     xm=ALLTRIM(姓名)
     rkmc=xm+","
     WordTable=WordApp.Application.Documents.Open(wjm)
     WordApp.Visible =.t.
     SELECT jsrkb
     GOTO top
     SCAN
         FOR i=1 TO 18
             m=FIELD(i)
             xm2= &m.
             IF ALLTRIM(xm2)=ALLTRIM(xm) then
                rkmc=rkmc+FIELD(i)+nj+bj+','
                zk( m,nj,bj)
             ENDIF
        NEXT i
     ENDSCAN
     WORDAPP.ActiveDocument.Content.Find.Execute('ABCDEF',.F.,.F.,.F.,.F.,.F.,.F.,.F.,.F.,'&xm',2)
     oFile=SYS(5)+SYS(2003)+"\"+ALLTRIM(xm)+"_课程表.doc"
     WordApp.Documents(1).SaveAs(oFile)
     WordApp.ActiveDocument.Close      
     SELECT jsmd
 ENDSCAN
 WORDAPP.quit
 WORDAPP=.NULL.
 CLOSE ALL
 QUIT
  
 PROCEDURE zk
     LPARAMETERS kcm,lnj,lbj
     LOCAL j,zkm,xq,jc,zkkm
      
     SELECT rkzb201803
     GOTO top
     LOCATE FOR ALLTRIM(nj)=ALLTRIM(lnj) AND ALLTRIM(bj)=ALLTRIM(lbj)
     IF NOT EOF() THEN
        FOR j=3 TO 32
            zkm=FIELD(j)
            zkkm= &zkm.
            IF ALLTRIM(zkkm)=ALLTRIM(kcm) then
               xq=VAL(SUBSTR(zkm,5,1))
               jc=VAL(SUBSTR(zkm,6,1))
               scsz=ALLTRIM(nj)+ALLTRIM(bj)+ALLTRIM(kcm)
               WordTable.Tables.item(1).Cell(jc+1,xq+2).Range.Text="&scsz"
            ENDIF
        NEXT j
     ENDIF
     SELECT jsrkb
     RETURN
2020-03-20 22:12
gs2536785678
Rank: 10Rank: 10Rank: 10
等 级:贵宾
威 望:45
帖 子:610
专家分:1784
注 册:2017-7-16
收藏
得分:7 
难了
2020-03-21 08:09
王咸美
Rank: 1
等 级:新手上路
帖 子:658
专家分:3
注 册:2018-1-4
收藏
得分:0 
还请高手指点,万分感谢!!!
2020-03-22 14:42
wcx_cc
Rank: 9Rank: 9Rank: 9
等 级:贵宾
威 望:52
帖 子:368
专家分:1157
注 册:2015-10-2
收藏
得分:7 
你这个问题里有3张表,但是我仔细看了看,发现 jsmd.dbf 是张无关的表,可以不用。与其他2张表没什么直接关联。我用其中2张表,按照你的要求做了一下,你看看合意不合意?vfp 9.0, 文档是 DOC的.
教课表.rar (8.01 KB)
2020-03-22 22:02
wcx_cc
Rank: 9Rank: 9Rank: 9
等 级:贵宾
威 望:52
帖 子:368
专家分:1157
注 册:2015-10-2
收藏
得分:0 
上面的例子中, prg 中有个 brow ,要去掉.否则,在游览时,如果指针不恢复在第1条记录上,会造成查询结果不正确.
2020-03-22 22:49
sdta
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:江苏省连云港市
等 级:版主
威 望:335
帖 子:9841
专家分:27213
注 册:2012-2-5
收藏
得分:7 
老师周上课节数统计
图片附件: 游客没有浏览图片的权限,请 登录注册

坚守VFP最后的阵地
2020-03-23 00:28
厨师王德榜
Rank: 18Rank: 18Rank: 18Rank: 18Rank: 18
等 级:贵宾
威 望:199
帖 子:989
专家分:4966
注 册:2013-2-16
收藏
得分:0 
我没有看你原来的代码,自己重起炉灶写的代码,我想,你的最终目的,是指定某个教师的姓名之后,由程序生成一个类似于这样表:
图片附件: 游客没有浏览图片的权限,请 登录注册
至于如何把这个表中的内容填充入Word? 我没时间研究,我想应该不难,所以我的代码,只到生成这样一张表截止,
后面的填充入Word的后续动作,靠你自己了.
2020-03-23 16:09
厨师王德榜
Rank: 18Rank: 18Rank: 18Rank: 18Rank: 18
等 级:贵宾
威 望:199
帖 子:989
专家分:4966
注 册:2013-2-16
收藏
得分:0 
代码在这里,这个代码,你也可以稍作修改,改为一个靠参数驱动的过程,这样就可以反复调用了:
程序代码:
LOCAL strName as String ,strTabName as String
strName = '陈羊成'   && 教师姓名,当然,你也可能稍作修改,把这个教师姓名改为参数,便于循环调用本模块.
strTabName = strName + "课时分布表"   && 最终输出表的名称,默认为:教师姓名 + 课时分布表,你也可以修改

* 运行以下语句前,假定已经打开了三个基本表:jsmd,jsrkb,rkzb201803,
* 如果未打开,自己添加一下打开的语句. 


 IF uGetKmbyXm (strName,'tmpTab1') THEN 
     = uTabZh ('tmpTab1','tmpTab2')
     IF uGetksxx('tmpTab2') THEN 
         = uMakeKSB('tmpTab2',strTabName) 
        USE IN tmpTab1
        USE IN tmpTab2  
        * 到此时,应该成功生成“XXX课时分布表”了
        * ...把这个表填充入Word的后续动作...由你自己补充
     ELSE 
        MESSAGEBOX('课时安排有冲突,请检查',16,'程序将返回') 
     ENDIF 

 ELSE 
    MESSAGEBOX('教师姓名=' + strName + ' 有误?,请检查',16,'程序将返回') 

 ENDIF 
*======================*======================*======================*
FUNCTION  uGetKmbyXm(paraJsxm as String,cTab as String) as Boolean
* 提取某教师的任课信息,多余信息清理掉 
* 参数:教师姓名 ,临时表别名
LOCAL cFn as String
LOCAL iCount as Integer ,ii as Integer
LOCAL lDele as Boolean 

SELECT jsmd 
LOCATE FOR jsmd.xm = paraJsxm
IF FOUND()
    IF USED(cTab) THEN 
        USE IN (cTab)
    ENDIF 
    IF USED('rkb') THEN 
        USE IN rkb 
    ENDIF     
    SELECT jsrkb.* FROM jsrkb INTO CURSOR rkb READWRITE 
    SELECT rkb
    iCount = FCOUNT('rkb') 
    FOR ii= iCount TO 3 STEP -1 
        cFn = fields(ii,'rkb')
        SELECT nj,bj,(cFn) as km,COUNT(*) as ts FROM rkb WHERE (&cFn)=paraJsxm GROUP BY 1,2,3 INTO CURSOR tmpkm 
        IF RECCOUNT('tmpkm')=0 THEN 
            ALTER table rkb drop COLUMN (cFn)         
        ENDIF 
        SELECT rkb 
        USE IN tmpkm
    ENDFOR 
    SELECT rkb 
    SCAN 
        lDele =.t. 
        FOR ii=3 TO FCOUNT('rkb') 
            cFn = fields(ii)
            IF  &cFn = paraJsxm THEN  
                lDele =.f. 

            ELSE 
                REPLACE &cFn WITH ''
            ENDIF 
        ENDFOR 
        IF lDele =.t. THEN 
            REPLACE rkb.nj WITH 'xxx' ,rkb.bj WITH 'xxx' 
        ENDIF 
    ENDSCAN 
    SELECT * FROM rkb INTO CURSOR (cTab) WHERE rkb.nj<>'xxx' AND rkb.bj<>'xxx' 
    USE IN rkb 
    RETURN .t.
ELSE 
    RETURN .f.
ENDIF 

ENDFUNC 

PROCEDURE uTabZh(cTab as String ,cTabOut as String )
* 把某表横转竖. 最终获取某教师课时列表 
* 参数1,要转换的表的别名.参数2,欲生成的表别名.
LOCAL xm as String ,km as String
LOCAL ii as Integer 
IF cTabOut=" " THEN 
    cTabOut = cTab + "_lst"
ENDIF 
IF USED(cTabOut) THEN 
    USE IN (cTabOut)
ENDIF 
    CREATE CURSOR (cTabOut) (nj c(10) ,bj c(10) ,jsxm c(10) ,kmmc c(10), ;
    周1第几节 i ,周2第几节 i ,周3第几节 i ,周4第几节 i ,周5第几节 i )
    SELECT (cTab)
    SCAN 
        FOR ii=3 TO FCOUNT(cTab) 
            km = FIELD(ii)
            xm = &km
            m.nj1 = &cTab..nj
            m.bj1 = &cTab..bj
            IF xm<>" " THEN 
                INSERT INTO (cTabOut) (nj ,bj,jsxm,kmmc) VALUES (m.nj1,m.bj1,xm,km)
            ENDIF 
        ENDFOR 
    ENDSCAN 

ENDPROC 

FUNCTION  uGetksxx(cTab as String ) as Boolean
* 在取得教师本周课时列表的基础上,填充其具体的课时信息.
LOCAL ii as Integer 
LOCAL cFn as String ,cFnItem as String ,qstr as String ,iday as String 
LOCAL iks as Integer
IF USED('tmpzks') THEN 
    USE IN tmpzks 
ENDIF 
SELECT rkzb201803.* FROM rkzb201803  ;
    inner JOIN (select &cTab..nj ,&cTab..bj FROM  (cTab) DISTINCT ) as tmp11 ;
     ON rkzb201803.nj = tmp11.nj  AND  rkzb201803.bj = tmp11.bj ;
     INTO CURSOR tmpzks
SELECT tmpzks
SCAN 
    m.nj1 = nj
    m.bj1 = bj
    FOR ii=3 TO FCOUNT('tmpzks') 
        cFn = FIELD(ii,'tmpzks')
        cFnItem = &cFn
        iDay = SUBSTR(cFn,5,1)
        iks = INT(VAL(SUBSTR(cFn,6,1)))
        qstr = "Update " + cTab + " set " + cTab + ".周" + iday + "第几节 = " + ;
            LTRIM(STR(iks)) + " Where " + cTab + ".nj = '" + m.nj1  + "' AND " + ;
            cTab + ".bj = '" + m.bj1 + "' AND " + cTab + ".kmmc = '" + cFnItem + "'" 
        &qstr 
        SELECT tmpzks        
    ENDFOR 
ENDSCAN 
USE IN tmpzks 
*  填充完毕,最好再检查一下有无冲突?比如同一天的节次现出两个,则不对.
FOR ii=1 TO 5
    qstr="SELECT " + cTab + ".jsxm,"  + cTab + ".周" + LTRIM(STR(ii)) + "第几节 as kkc,COUNT(*) as ts FROM " + cTab + ;
        " Where " + cTab + ".周" + LTRIM(STR(ii)) + "第几节>0  GROUP BY jsxm,周" + LTRIM(STR(ii)) + ;
        "第几节 HAVING ts>1 INTO CURSOR tmp33 "
    &qstr 
    IF RECCOUNT('tmp33')>0 THEN 
        MESSAGEBOX("教师:" +RTRIM(tmp33.jsxm) + ",周" + LTRIM(STR(ii)) + ;
        "第" + LTRIM(STR(tmp33.kkc)) + "节课被重复安排了" + LTRIM(STR(tmp33.ts)) + "次?请检查!" ,;
        16,"程序检测到课时冲突")
        RETURN  .f. 
        EXIT for 
    ELSE 
        USE IN tmp33
    ENDIF 
ENDFOR 
RETURN  .t. 
ENDFUNC 

PROCEDURE uMakeKSB(cTab as String ,cTabOut as String)
* 根据参数1(别名) 生成正式的课时表(参数2)
LOCAL II AS Integer ,ijc as Integer 
LOCAL strItem as String ,cfn as String,xm as String ,qstr as String
IF USED(cTabOut) THEN 
    USE IN (cTabOut)
ENDIF 
CREATE CURSOR (cTabOut) (教师姓名 c(20) ,午别 c(4) ,节次 i ,星期1 c(20),星期2 c(20),星期3 c(20),星期4 c(20),星期5 c(20)) 
FOR ii = 1 TO 6  && 学校一天有N节课,这里就循环N次
    INSERT INTO (cTabOut) (午别  ,节次 ) VALUES (IIF(ii<=3,'上午','下午') , ii) 
ENDFOR 
SELECT (cTab)
GO TOP 
SCAN 
    FOR ii=1 TO 5
        cfn = "周" + LTRIM(STR(ii)) + "第几节"
        ijc = &cfn
        IF ijc<>0 THEN 
            xm = RTRIM(jsxm )
            strItem = RTRIM(nj) + RTRIM(bj) + "," + RTRIM(kmmc) 
            qstr="UPDATE " + cTabOut + " SET 星期" + LTRIM(STR(ii)) + "='" + STRitem + ;
                "', 教师姓名='" + xm + "' Where 节次="  +  LTRIM(STR(ijc)) 
            &qstr 
        ENDIF 
    ENDFOR 
ENDSCAN 

ENDPROC 


[此贴子已经被作者于2020-3-23 17:19编辑过]

2020-03-23 16:13
快速回复:如何统计每位老师每周上课节数
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.035109 second(s), 9 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved