草庐IT

windows - 如何正常排序?

coder 2024-06-14 原文

如何在 Windows 命令行中进行不同的排序? 我浏览了几个网站,包括这个 http://ss64.com/nt/dir.html ,但我看不到按我想要的方式排序的方法。 目前我正在使用:

dir *.txt /s /o:d /b >> "sorted.txt"

目前是这样排序的:

file1.txt
file10.txt
file11.txt
...
file2.txt
file20.txt
file21.txt

我希望它像这样“正常”排序:

file1.txt
file2.txt
file3.txt
file4.txt
file5.txt
file6.txt

另外我正在使用/s 并且想知道是否有一种方法可以不返回完整路径,而只返回文件名,如上所示。谢谢!

最佳答案

Windows CMD 排序为 1>10>2>20>3>4>50>6 你正在寻找的是所谓的“自然排序”,
我正在使用一个非常基本但设计良好的算法,
用 JavaScript 编写,
因为它本身支持 UTF-8 并与 NodeJS 一起使用,
它可以非常轻松地读取、修改和写入文件。

这是自然排序的基本算法:

function natural_compare(a, b){
  var ax=[], bx=[];
  
  a.replace(/(\d+)|(\D+)/g, function(_, $1, $2){ ax.push([$1 || Infinity, $2 || ""]); });
  b.replace(/(\d+)|(\D+)/g, function(_, $1, $2){ bx.push([$1 || Infinity, $2 || ""]); });

  while(ax.length > 0 && bx.length > 0){
    var an, bn, nn;
    
    an = ax.shift();
    bn = bx.shift();
    nn = (an[0] - bn[0]) || an[1].localeCompare(bn[1]);
    if(nn) return nn;
  }
  return ax.length - bx.length;
}

然后将它应用于数组的排序方法,
作为默认排序行为的替代方法。


  1. > 将其保存到名为“index.js”的文件中:
    "use strict";
    
    function natural_compare(a, b){
      var ax=[], bx=[];
      
      a.replace(/(\d+)|(\D+)/g, function(_, $1, $2){ ax.push([$1 || Infinity, $2 || ""]); });
      b.replace(/(\d+)|(\D+)/g, function(_, $1, $2){ bx.push([$1 || Infinity, $2 || ""]); });
    
      while(ax.length > 0 && bx.length > 0){
        var an, bn, nn;
        
        an = ax.shift();
        bn = bx.shift();
        nn = (an[0] - bn[0]) || an[1].localeCompare(bn[1]);
        if(nn) return nn;
      }
      return ax.length - bx.length;
    }
    
    
    const FS                = require("fs")
         ,PATH              = require("path")
         ,resolve           = function(path){
                                path = path.replace(/\"/g,"");
                                path = path.replace(/\\+/g,"/");
                                path = PATH.resolve(path); 
                                path = path.replace(/\\+/g,"/"); 
                                path = path.replace(/\/\/+/g,"/"); 
                                return path;
                              }
         ,ARGS              = process.argv.filter(function(s){return false === /node\.exe/i.test(s) && false === /index\.js/i.test(s);}).map(function(s){return s.replace(/\"/gm,"");})
         ,FILE_IN           = resolve(ARGS[0])
         ,FILE_IN_PARTS     = PATH.parse(FILE_IN)
         ,FILE_OUT          = resolve(
                                FILE_IN_PARTS.dir  
                              + "/" 
                              + FILE_IN_PARTS.name 
                              + "_sorted_uniqued"
                              + FILE_IN_PARTS.ext
                              )
         ;
    
    
    var   tmp                = new Object(null)
         ,content            = FS.readFileSync(FILE_IN, {encoding:"utf8"})               //raw text-content
                                .replace(/[\r\n]+/gm, "\n").replace(/\n+/gm, "\n")       //unify newline character, single newline the most.
                                .split("\n").filter(function(s){return s.length > 1;})   //no empty lines. whitespace is considered a perfectly valid content. if you do wish to remove all-whitespace lines and empty lines pre-include this line before this one:   .replace(/^\s*/g, "").replace(/(\s*$|^\s*)/gm, "")
         ;
    
    //-------------------------------------------------unique
    content.forEach(function(s){
      tmp[1] = 1;
    });
    content = Object.keys(tmp);
    tmp = undefined;
    //---------------------------------------------------------
    
    content = content.sort(natural_compare)
                     .join("\r\n")
                     ;
    
    FS.writeFileSync(FILE_OUT, content, {flag:"w", encoding:"utf8"}); //overwrite
    
  2. > 从 https://nodejs.org/download/nightly/v17.0.0-nightly2021100628f711b552/win-x86/node.exe 下载单个服务的 `node.exe` .
  3. > 将其添加到名为“sort.cmd”的文件中:
    @echo off
    chcp 65001 1>nul 2>nul
    call "%~sdp0node.exe" "%~sdp0index.js" %*
    exit /b %ErrorLevel%
    
  4. > 将所有 3 个文件放在您喜欢的任何文件夹中, 当您将任何文件拖放到 `sort.cmd` 上时, 您将获得一个新文件,其文本内容已排序(且唯一)。

结果文件的行将使用 Windows EOL (CR+LF) 连接。

几年来它对我来说非常有效,
跳过所有其他批处理文件特定的怪癖(..CMD 处理原始 Unicode.. Brrrr...?)

它也是一个独立于操作系统的解决方案,
因为你真的不需要 cmd 文件来运行 NodeJS 脚本,
只需将文件路径指定为 NodeJS 的参数,
并下载您的操作系统版本的 NodeJS
(如果您愿意,还可以更改 EOL 字符)。


您可以在以下位置寻找其他解决方案:
https://github.com/search?q=natural+sort+batch+file&type=Repositories 但是没有很多客户就绪的解决方案。

关于windows - 如何正常排序?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39309634/

有关windows - 如何正常排序?的更多相关文章

  1. ruby - 如何使用 Nokogiri 的 xpath 和 at_xpath 方法 - 2

    我正在学习如何使用Nokogiri,根据这段代码我遇到了一些问题:require'rubygems'require'mechanize'post_agent=WWW::Mechanize.newpost_page=post_agent.get('http://www.vbulletin.org/forum/showthread.php?t=230708')puts"\nabsolutepathwithtbodygivesnil"putspost_page.parser.xpath('/html/body/div/div/div/div/div/table/tbody/tr/td/div

  2. ruby - 如何从 ruby​​ 中的字符串运行任意对象方法? - 2

    总的来说,我对ruby​​还比较陌生,我正在为我正在创建的对象编写一些rspec测试用例。许多测试用例都非常基础,我只是想确保正确填充和返回值。我想知道是否有办法使用循环结构来执行此操作。不必为我要测试的每个方法都设置一个assertEquals。例如:describeitem,"TestingtheItem"doit"willhaveanullvaluetostart"doitem=Item.new#HereIcoulddotheitem.name.shouldbe_nil#thenIcoulddoitem.category.shouldbe_nilendend但我想要一些方法来使用

  3. ruby - 在 Ruby 程序执行时阻止 Windows 7 PC 进入休眠状态 - 2

    我需要在客户计算机上运行Ruby应用程序。通常需要几天才能完成(复制大备份文件)。问题是如果启用sleep,它会中断应用程序。否则,计算机将持续运行数周,直到我下次访问为止。有什么方法可以防止执行期间休眠并让Windows在执行后休眠吗?欢迎任何疯狂的想法;-) 最佳答案 Here建议使用SetThreadExecutionStateWinAPI函数,使应用程序能够通知系统它正在使用中,从而防止系统在应用程序运行时进入休眠状态或关闭显示。像这样的东西:require'Win32API'ES_AWAYMODE_REQUIRED=0x0

  4. python - 如何使用 Ruby 或 Python 创建一系列高音调和低音调的蜂鸣声? - 2

    关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭4年前。Improvethisquestion我想在固定时间创建一系列低音和高音调的哔哔声。例如:在150毫秒时发出高音调的蜂鸣声在151毫秒时发出低音调的蜂鸣声200毫秒时发出低音调的蜂鸣声250毫秒的高音调蜂鸣声有没有办法在Ruby或Python中做到这一点?我真的不在乎输出编码是什么(.wav、.mp3、.ogg等等),但我确实想创建一个输出文件。

  5. ruby-on-rails - 由于 "wkhtmltopdf",PDFKIT 显然无法正常工作 - 2

    我在从html页面生成PDF时遇到问题。我正在使用PDFkit。在安装它的过程中,我注意到我需要wkhtmltopdf。所以我也安装了它。我做了PDFkit的文档所说的一切......现在我在尝试加载PDF时遇到了这个错误。这里是错误:commandfailed:"/usr/local/bin/wkhtmltopdf""--margin-right""0.75in""--page-size""Letter""--margin-top""0.75in""--margin-bottom""0.75in""--encoding""UTF-8""--margin-left""0.75in""-

  6. ruby-on-rails - 如何验证 update_all 是否实际在 Rails 中更新 - 2

    给定这段代码defcreate@upgrades=User.update_all(["role=?","upgraded"],:id=>params[:upgrade])redirect_toadmin_upgrades_path,:notice=>"Successfullyupgradeduser."end我如何在该操作中实际验证它们是否已保存或未重定向到适当的页面和消息? 最佳答案 在Rails3中,update_all不返回任何有意义的信息,除了已更新的记录数(这可能取决于您的DBMS是否返回该信息)。http://ar.ru

  7. ruby-on-rails - 'compass watch' 是如何工作的/它是如何与 rails 一起使用的 - 2

    我在我的项目目录中完成了compasscreate.和compassinitrails。几个问题:我已将我的.sass文件放在public/stylesheets中。这是放置它们的正确位置吗?当我运行compasswatch时,它不会自动编译这些.sass文件。我必须手动指定文件:compasswatchpublic/stylesheets/myfile.sass等。如何让它自动运行?文件ie.css、print.css和screen.css已放在stylesheets/compiled。如何在编译后不让它们重新出现的情况下删除它们?我自己编译的.sass文件编译成compiled/t

  8. ruby - 如何将脚本文件的末尾读取为数据文件(Perl 或任何其他语言) - 2

    我正在寻找执行以下操作的正确语法(在Perl、Shell或Ruby中):#variabletoaccessthedatalinesappendedasafileEND_OF_SCRIPT_MARKERrawdatastartshereanditcontinues. 最佳答案 Perl用__DATA__做这个:#!/usr/bin/perlusestrict;usewarnings;while(){print;}__DATA__Texttoprintgoeshere 关于ruby-如何将脚

  9. ruby - 如何指定 Rack 处理程序 - 2

    Rackup通过Rack的默认处理程序成功运行任何Rack应用程序。例如:classRackAppdefcall(environment)['200',{'Content-Type'=>'text/html'},["Helloworld"]]endendrunRackApp.new但是当最后一行更改为使用Rack的内置CGI处理程序时,rackup给出“NoMethodErrorat/undefinedmethod`call'fornil:NilClass”:Rack::Handler::CGI.runRackApp.newRack的其他内置处理程序也提出了同样的反对意见。例如Rack

  10. ruby - 如何每月在 Heroku 运行一次 Scheduler 插件? - 2

    在选择我想要运行操作的频率时,唯一的选项是“每天”、“每小时”和“每10分钟”。谢谢!我想为我的Rails3.1应用程序运行调度程序。 最佳答案 这不是一个优雅的解决方案,但您可以安排它每天运行,并在实际开始工作之前检查日期是否为当月的第一天。 关于ruby-如何每月在Heroku运行一次Scheduler插件?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/8692687/

随机推荐