中国DOS联盟论坛

中国DOS联盟

-- 联合DOS 推动DOS 发展DOS --

联盟域名:www.cn-dos.net  论坛域名:www.cn-dos.net/forum
DOS,代表着自由开放与发展,我们努力起来,学习FreeDOS和Linux的自由开放与GNU精神,共同创造和发展美好的自由与GNU GPL世界吧!

游客:  注册 | 登录 | 命令行 | 会员 | 搜索 | 上传 | 帮助 »
中国DOS联盟论坛 » DOS批处理 & 脚本技术(批处理室) » 如何给新员工分配工号?合并两张表
作者:
标题: 如何给新员工分配工号?合并两张表 上一主题 | 下一主题
uiopuiop
中级用户





积分 400
发帖 211
注册 2007-9-30
状态 离线
『楼 主』:  如何给新员工分配工号?合并两张表

有两张表,如何自动给新员工分配员工号?合并两张表,得到NEW.txt


Employee.txt 包含如下内容
zhao,NEW
qian, OLD
sun, NEW
li, OLD
zhou, NEW
wu,TEMP

NEW.txt 包含如下内容 (新员工工号)
100
101
102


NEW2.txt 需要得到以下内容:
zhao,NEW, 100
qian, OLD
sun, NEW, 101
li, OLD
zhou, NEW, 102
wu,TEMP

[ Last edited by uiopuiop on 2009-4-23 at 03:23 ]

2009-4-23 01:56
查看资料  发短消息 网志   编辑帖子  回复  引用回复
tireless
银牌会员





积分 2025
发帖 1122
注册 2007-9-5
状态 离线
『第 2 楼』:  

如果 NEW.txt 里面的数字后一位比前一位大1:
@echo off&setlocal enabledelayedexpansion
set /p n=<new.txt
(for /f "tokens=1,2 delims=, " %%a in (Employee.txt) do (
  if /i "%%b"=="NEW" (
    echo.%%a, %%b, !n!
    set /a n+=1
  ) else echo.%%a, %%b
))>NEW2.txt
start NEW2.txt


2009-4-23 03:25
查看资料  发短消息 网志   编辑帖子  回复  引用回复
uiopuiop
中级用户





积分 400
发帖 211
注册 2007-9-30
状态 离线
『第 3 楼』:  



  Quote:
Originally posted by tireless at 2009-4-23 03:25 AM:
如果 NEW.txt 里面的数字后一位比前一位大1:
[code]@echo off&setlocal enabledelayedexpansion
set /p n=<new.txt
(for /f "tokens=1,2 delims=, " %%a in (Employee.txt) ...

不好意思,在实际情况下NEW.txt 里面的不一定是数字而且是没有规律字符串。
想到要 用 set /a num+=1 给每个符合的记录编号,但想不出有什么简便的算法。

[ Last edited by uiopuiop on 2009-4-23 at 04:16 ]

2009-4-23 04:09
查看资料  发短消息 网志   编辑帖子  回复  引用回复
tireless
银牌会员





积分 2025
发帖 1122
注册 2007-9-5
状态 离线
『第 4 楼』:  


@echo off&setlocal enabledelayedexpansion
set n=
for /f "tokens=*" %%a in (new.txt) do (
  set /a n+=1
  set #!n!=%%a
)

set n=
(for /f "tokens=1,2 delims=, " %%a in (Employee.txt) do (
  if /i "%%b"=="new" (
    set /a n+=1
    for %%i in (#!n!) do echo.%%a, %%b, !%%i!
  ) else echo.%%a, %%b
))>NEW2.txt
p.s. 员工号位数是否一致?

[ Last edited by tireless on 2009-4-23 at 04:26 ]

   此帖被 +2 点积分      点击查看详情   
评分人:【 uiopuiop 分数: +2  时间:2009-4-23 04:30


2009-4-23 04:22
查看资料  发短消息 网志   编辑帖子  回复  引用回复
uiopuiop
中级用户





积分 400
发帖 211
注册 2007-9-30
状态 离线
『第 5 楼』:  

re: 员工号位数是否一致? 不一致,我这里只是举个例子,实际情况可能是一个随机的EMAIL 地址。

set #!n!=%%a
中#n表示什么?

echo.ab 和 echo ab有什么区别?

[ Last edited by uiopuiop on 2009-4-23 at 04:38 ]

2009-4-23 04:30
查看资料  发短消息 网志   编辑帖子  回复  引用回复
tireless
银牌会员





积分 2025
发帖 1122
注册 2007-9-5
状态 离线
『第 6 楼』:  Re 5楼

# 是变量名的一部分。有点多余了,可以把代码中的 # 去掉。

echo.ab 中的点也多余了。。。可以去掉。加一个点是为了防止后面的字符是 on 或 off,造成 echo on 或 echo off;要输出空行时也要加点。

[ Last edited by tireless on 2009-4-23 at 04:46 ]

2009-4-23 04:41
查看资料  发短消息 网志   编辑帖子  回复  引用回复
uiopuiop
中级用户





积分 400
发帖 211
注册 2007-9-30
状态 离线
『第 7 楼』:  

很经典,简洁,多谢!

2009-4-23 04:53
查看资料  发短消息 网志   编辑帖子  回复  引用回复
mmh1
初级用户





积分 20
发帖 24
注册 2009-3-18
状态 离线
『第 8 楼』:  

3楼,4楼的我试了下,怎么不行啊????
结果:
hao,NEW,
qian, OLD
sun, NEW, 100
li, OLD
zhou, NEW, 101
wu, TEMP

2009-4-23 05:06
查看资料  发送邮件  发短消息 网志   编辑帖子  回复  引用回复
freeants001
中级用户




积分 330
发帖 244
注册 2006-4-14
来自 湖北
状态 离线
『第 9 楼』:  

haoNEW,
qian, OLD
sun, NEW, 100
li, OLD
zhou, NEW, 101
wu, TEMP

2009-4-23 05:11
查看资料  发送邮件  发短消息 网志   编辑帖子  回复  引用回复
freeants001
中级用户




积分 330
发帖 244
注册 2006-4-14
来自 湖北
状态 离线
『第 10 楼』:  

来个JS的
fso=WScript.createobject("scripting.filesystemobject");
f1=fso.opentextfile("Employee.txt")
f2=fso.opentextfile("NEW.txt");
f3=fso.createtextfile("$_dest.txt",1)
re=/\bNEW[ \t]*$/i;
while(!f1.AtEndOfStream){
    sss=f1.readline();
    if(re.test(sss))sss=sss.replace(re,"NEW,"+f2.readline());
    f3.writeline(sss);
}


2009-4-23 05:13
查看资料  发送邮件  发短消息 网志   编辑帖子  回复  引用回复
jmz573515
银牌会员




积分 1212
发帖 464
注册 2006-12-13
状态 离线
『第 11 楼』:  


on error resume next
set fso=createobject("scripting.filesystemobject")
set f1=fso.opentextfile("Employee.txt")
set f2=fso.opentextfile("NEW.txt")
set f3=fso.createtextfile("Employee_new.txt")
do while f1.atendofstream<>true
        n=f1.readline
        if f1.line mod 2=0 then
                sm=sm &n & "," & f2.readline & vbcrlf
                if err then err.caler
        else
                sm=sm & n & vbcrlf
        end if
loop
f3.write sm
f1.close
f2.close
f3.close
set fso=nothing
[ Last edited by jmz573515 on 2009-4-23 at 21:58 ]

2009-4-23 21:53
查看资料  发送邮件  发短消息 网志   编辑帖子  回复  引用回复

请注意:您目前尚未注册或登录,请您注册登录以使用论坛的各项功能,例如发表和回复帖子等。


可打印版本 | 推荐给朋友 | 订阅主题 | 收藏主题



论坛跳转: