[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
返回列表 发帖

[文本处理] [已解决]批处理如何根据一个文本的第一列内容提取另一文本第一列相同内容对应的行?

本帖最后由 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文件处理,谢谢。
1

评分人数

  1. findstr /G:b.txt a.txt>c.txt
复制代码
#&cls&@powershell "Invoke-Expression ([Io.File]::ReadAllText('%~0',[Text.Encoding]::UTF8))" &pause&exit

TOP

本帖最后由 qixiaobin0715 于 2021-12-7 11:42 编辑

回复 2# ivor
够简洁的,看来以后要好好学习了。但还有一点问题,比如需要提取的是after,但是afternoon也一起提取出来了。
若要提取a,所有以a开头的都提取出来了。
https://mp.weixin.qq.com/s/6lbb97qUOs1sTyKJfN0ZEQ

TOP

回复 1# qixiaobin0715
  1. @echo off
  2. (for /f %%a in (b.txt) do (
  3. findstr /R "\<%%a\>" a.txt
  4. ))>c.txt
复制代码
#&cls&@powershell "Invoke-Expression ([Io.File]::ReadAllText('%~0',[Text.Encoding]::UTF8))" &pause&exit

TOP

回复 4# ivor
谢谢了,解决了99%的问题。
还有一种情况:就是如果存在a和a little情况,a和a little分别提取两次,不知好不好解决。

TOP

回复 5# qixiaobin0715
加两空格就行

TOP

回复 6# happy886rr

请教一下,是在那个地方加空格。

TOP

回复 4# ivor
感谢ivor提供的代码。为了能够提取词组比如get up,作了如下修改:
1.for /f后加上了"delims=",保证读取词组,避免以空格分隔,只能读取如get。
2.在/R后增加了/b /c:,只从文件行的开始匹配字符(以免后面的内容产生干扰),并且以整个词组作为字符串提取。
虽然还有瑕疵,但不影响大局。再次感谢ivor的热心帮助。
1

评分人数

TOP

回复 5# qixiaobin0715

单词和中文翻译之间的间隔还是蛮大

TOP

回复 9# pcl_test
谢谢您及happy886rr的提醒,开始没想到,单词和释义之间有三个空格,在代码/>前增加两个空格,问题完美解决。再次感谢!!!

TOP

  1. @echo off
  2. setlocal enabledelayedexpansion
  3. for /f "delims=" %%i in (b.txt) do (
  4. set "_%%i=A"
  5. )
  6. (for /f "tokens=1,* delims= " %%i in (a.txt) do (
  7. if defined _%%i echo,%%i %%j
  8. )) >c.txt
  9. pause
复制代码
1

评分人数

    • codegay: 谁的小号呢这是.技术 + 1

TOP

回复 11# apython
提供了另一个思路。谢谢了!!!

TOP

回复 11# apython
请问:
set "_%%i=A"
表示什么意思?

TOP

回复 13# qixiaobin0715


    对其进行赋值,然后在下一句for命令中进行调用。if 判断相关信息是否被赋值。

TOP

返回列表