标题: [文本处理] [已解决]批处理如何根据一个文本的第一列内容提取另一文本第一列相同内容对应的行? [打印本页]
作者: qixiaobin0715 时间: 2016-3-21 07:19 标题: [已解决]批处理如何根据一个文本的第一列内容提取另一文本第一列相同内容对应的行?
本帖最后由 pcl_test 于 2016-8-4 23:18 编辑
如题a.txt内容
attend vt.出席;照顾,护理
away ad.离开,远离;⋯去
baby n.一家中年龄最小的人
back adv.回(原处);向后
bad a.坏的,恶的;严重的
bag n.提包,口袋,书包
.....
b.txt内容
away
back
bag
band
根据b文件的内容提取a文件内容到c.txt为
away ad.离开,远离;⋯去
back adv.回(原处);向后
bag n.提包,口袋,书包
band n.乐队;带;波段
最好用bat文件处理,谢谢。
作者: ivor 时间: 2016-3-21 09:13
- findstr /G:b.txt a.txt>c.txt
复制代码
作者: qixiaobin0715 时间: 2016-3-21 09:58
本帖最后由 qixiaobin0715 于 2021-12-7 11:42 编辑
回复 2# ivor
够简洁的,看来以后要好好学习了。但还有一点问题,比如需要提取的是after,但是afternoon也一起提取出来了。
若要提取a,所有以a开头的都提取出来了。
https://mp.weixin.qq.com/s/6lbb97qUOs1sTyKJfN0ZEQ
作者: ivor 时间: 2016-3-21 11:01
回复 1# qixiaobin0715 - @echo off
- (for /f %%a in (b.txt) do (
- findstr /R "\<%%a\>" a.txt
- ))>c.txt
复制代码
作者: qixiaobin0715 时间: 2016-3-21 11:38
回复 4# ivor
谢谢了,解决了99%的问题。
还有一种情况:就是如果存在a和a little情况,a和a little分别提取两次,不知好不好解决。
作者: happy886rr 时间: 2016-3-21 11:48
回复 5# qixiaobin0715
加两空格就行
作者: qixiaobin0715 时间: 2016-3-21 11:54
回复 6# happy886rr
请教一下,是在那个地方加空格。
作者: qixiaobin0715 时间: 2016-3-22 22:34
回复 4# ivor
感谢ivor提供的代码。为了能够提取词组比如get up,作了如下修改:
1.for /f后加上了"delims=",保证读取词组,避免以空格分隔,只能读取如get。
2.在/R后增加了/b /c:,只从文件行的开始匹配字符(以免后面的内容产生干扰),并且以整个词组作为字符串提取。
虽然还有瑕疵,但不影响大局。再次感谢ivor的热心帮助。
作者: pcl_test 时间: 2016-3-22 23:07
回复 5# qixiaobin0715
单词和中文翻译之间的间隔还是蛮大
作者: qixiaobin0715 时间: 2016-3-23 07:15
回复 9# pcl_test
谢谢您及happy886rr的提醒,开始没想到,单词和释义之间有三个空格,在代码/>前增加两个空格,问题完美解决。再次感谢!!!
作者: apython 时间: 2016-3-23 22:21
- @echo off
- setlocal enabledelayedexpansion
- for /f "delims=" %%i in (b.txt) do (
- set "_%%i=A"
- )
- (for /f "tokens=1,* delims= " %%i in (a.txt) do (
- if defined _%%i echo,%%i %%j
- )) >c.txt
- pause
复制代码
作者: qixiaobin0715 时间: 2016-3-23 23:22
回复 11# apython
提供了另一个思路。谢谢了!!!
作者: qixiaobin0715 时间: 2016-4-12 13:46
回复 11# apython
请问:
set "_%%i=A"
表示什么意思?
作者: apython 时间: 2016-4-13 18:09
回复 13# qixiaobin0715
对其进行赋值,然后在下一句for命令中进行调用。if 判断相关信息是否被赋值。
欢迎光临 批处理之家 (http://bathome.net./) |
Powered by Discuz! 7.2 |