Author Topic: alternative to vl-directory-files  (Read 3022 times)

0 Members and 1 Guest are viewing this topic.

Andrea

  • Water Moccasin
  • Posts: 2372
alternative to vl-directory-files
« on: December 08, 2015, 08:19:30 AM »
Hi Guys,

i'm actually trying to find some alternative to vl-directory-files
this function take around 5 to 7 sec before showing result on a folder containing over 4000 files.

By now, I came up by creating a CMD file containing DIR function and put the result in a TXT file,..
Then, read the TXT,...is a way faster !

Code: [Select]
"Dir \\\\myserver\\myfolder\\mydata\\files\\*.log /L/-D > c:\\temp\\temp.txt"
But I would like to know if any of you have some idea or suggestions...
Thank you.
Keep smile...

Lee Mac

  • Seagull
  • Posts: 12914
  • London, England
Re: alternative to vl-directory-files
« Reply #1 on: December 08, 2015, 09:10:47 AM »
Good idea Andrea  :-)

You could use the FSO as another alternative to vl-directory-files, but this is unlikely to be any quicker.

ronjonp

  • Needs a day job
  • Posts: 7529
Re: alternative to vl-directory-files
« Reply #2 on: December 08, 2015, 09:19:46 AM »
Good idea Andrea  :)

You could use the FSO as another alternative to vl-directory-files, but this is unlikely to be any quicker.


Exactly :)
Code - Auto/Visual Lisp: [Select]
  1. Benchmarking ...Elapsed milliseconds / relative speed for 1 iteration(s):
  2.  
  3.  
  4.     (VL-DIRECTORY-FILES "G:\\Ron" "*.*" 1).....1797 / 2.46 <fastest>
  5.     (_SFSOGETFILES "G:\\Ron")..................4422 / 1.00 <slowest>

Windows 11 x64 - AutoCAD /C3D 2023

Custom Build PC

Andrea

  • Water Moccasin
  • Posts: 2372
Re: alternative to vl-directory-files
« Reply #3 on: December 08, 2015, 09:23:45 AM »
Thank you guys,..
same test I've made..

question...is there any way to capture the DIR dos Value without putting the result in a txt file ?
I've made some research on the web but unfortunatly,..seem that I cannot find anything about it..

 :rolleyes2:

Keep smile...

JohnK

  • Administrator
  • Seagull
  • Posts: 10646
Re: alternative to vl-directory-files
« Reply #4 on: December 08, 2015, 09:27:14 AM »
I have done that in the past as well. Except I used the LS (list) program from the GNU tools (LS is like DIR). There are a lot more options to LS then DIR and I used LS to do some of the processing instead of my program. -e.g. with LS you can filter out file types being listed.

Below is the help file from LS so you can get a better idea of what I am talking about.

You can get Wini32 binaries of the GNU tools many different places (you may even have them on your PC already) but I like these (esier to use; just unzip and run):
http://unxutils.sourceforge.net/


Code: [Select]
Usage: ls [OPTION]... [FILE]...
List information about the FILEs (the current directory by default).
Sort entries alphabetically if none of -cftuvSUX nor --sort is specified.

Mandatory arguments to long options are mandatory for short options too.
  -a, --all                  do not ignore entries starting with .
  -A, --almost-all           do not list implied . and ..
      --author               with -l, print the author of each file
  -b, --escape               print C-style escapes for nongraphic characters
      --block-size=SIZE      scale sizes by SIZE before printing them; e.g.,
                               '--block-size=M' prints sizes in units of
                               1,048,576 bytes; see SIZE format below
  -B, --ignore-backups       do not list implied entries ending with ~
  -c                         with -lt: sort by, and show, ctime (time of last
                               modification of file status information);
                               with -l: show ctime and sort by name;
                               otherwise: sort by ctime, newest first
  -C                         list entries by columns
      --color[=WHEN]         colorize the output; WHEN can be 'always' (default
                               if omitted), 'auto', or 'never'; more info below
  -d, --directory            list directories themselves, not their contents
  -D, --dired                generate output designed for Emacs' dired mode
  -f                         do not sort, enable -aU, disable -ls --color
  -F, --classify             append indicator (one of */=>@|) to entries
      --file-type            likewise, except do not append '*'
      --format=WORD          across -x, commas -m, horizontal -x, long -l,
                               single-column -1, verbose -l, vertical -C
      --full-time            like -l --time-style=full-iso
  -g                         like -l, but do not list owner
      --group-directories-first
                             group directories before files;
                               can be augmented with a --sort option, but any
                               use of --sort=none (-U) disables grouping
  -G, --no-group             in a long listing, don't print group names
  -h, --human-readable       with -l and/or -s, print human readable sizes
                               (e.g., 1K 234M 2G)
      --si                   likewise, but use powers of 1000 not 1024
  -H, --dereference-command-line
                             follow symbolic links listed on the command line
      --dereference-command-line-symlink-to-dir
                             follow each command line symbolic link
                               that points to a directory
      --hide=PATTERN         do not list implied entries matching shell PATTERN
                               (overridden by -a or -A)
      --indicator-style=WORD  append indicator with style WORD to entry names:
                               none (default), slash (-p),
                               file-type (--file-type), classify (-F)
  -i, --inode                print the index number of each file
  -I, --ignore=PATTERN       do not list implied entries matching shell PATTERN
  -k, --kibibytes            default to 1024-byte blocks for disk usage
  -l                         use a long listing format
  -L, --dereference          when showing file information for a symbolic
                               link, show information for the file the link
                               references rather than for the link itself
  -m                         fill width with a comma separated list of entries
  -n, --numeric-uid-gid      like -l, but list numeric user and group IDs
  -N, --literal              print raw entry names (don't treat e.g. control
                               characters specially)
  -o                         like -l, but do not list group information
  -p, --indicator-style=slash
                             append / indicator to directories
  -q, --hide-control-chars   print ? instead of nongraphic characters
      --show-control-chars   show nongraphic characters as-is (the default,
                               unless program is 'ls' and output is a terminal)
  -Q, --quote-name           enclose entry names in double quotes
      --quoting-style=WORD   use quoting style WORD for entry names:
                               literal, locale, shell, shell-always, c, escape
  -r, --reverse              reverse order while sorting
  -R, --recursive            list subdirectories recursively
  -s, --size                 print the allocated size of each file, in blocks
  -S                         sort by file size, largest first
      --sort=WORD            sort by WORD instead of name: none (-U), size (-S),
                               time (-t), version (-v), extension (-X)
      --time=WORD            with -l, show time as WORD instead of default
                               modification time: atime or access or use (-u);
                               ctime or status (-c); also use specified time
                               as sort key if --sort=time (newest first)
      --time-style=STYLE     with -l, show times using style STYLE:
                               full-iso, long-iso, iso, locale, or +FORMAT;
                               FORMAT is interpreted like in 'date'; if FORMAT
                               is FORMAT1<newline>FORMAT2, then FORMAT1 applies
                               to non-recent files and FORMAT2 to recent files;
                               if STYLE is prefixed with 'posix-', STYLE
                               takes effect only outside the POSIX locale
  -t                         sort by modification time, newest first
  -T, --tabsize=COLS         assume tab stops at each COLS instead of 8
  -u                         with -lt: sort by, and show, access time;
                               with -l: show access time and sort by name;
                               otherwise: sort by access time, newest first
  -U                         do not sort; list entries in directory order
  -v                         natural sort of (version) numbers within text
  -w, --width=COLS           assume screen width instead of current value
  -x                         list entries by lines instead of by columns
  -X                         sort alphabetically by entry extension
  -Z, --context              print any security context of each file
  -1                         list one file per line.  Avoid '\n' with -q or -b
      --append-exe           append .exe if cygwin magic was needed
      --help     display this help and exit
      --version  output version information and exit

The SIZE argument is an integer and optional unit (example: 10K is 10*1024).
Units are K,M,G,T,P,E,Z,Y (powers of 1024) or KB,MB,... (powers of 1000).

Using color to distinguish file types is disabled both by default and
with --color=never.  With --color=auto, ls emits color codes only when
standard output is connected to a terminal.  The LS_COLORS environment
variable can change the settings.  Use the dircolors command to set it.

Exit status:
 0  if OK,
 1  if minor problems (e.g., cannot access subdirectory),
 2  if serious trouble (e.g., cannot access command-line argument).

GNU coreutils online help: <http://www.gnu.org/software/coreutils/>
Report ls translation bugs to <http://translationproject.org/team/>
Full documentation at: <http://www.gnu.org/software/coreutils/ls>
or available locally via: info '(coreutils) ls invocation'
« Last Edit: December 08, 2015, 09:34:53 AM by John Kaul (Se7en) »
TheSwamp.org (serving the CAD community since 2003)
Member location map - Add yourself

Donate to TheSwamp.org

Andrea

  • Water Moccasin
  • Posts: 2372
Re: alternative to vl-directory-files
« Reply #5 on: December 08, 2015, 10:54:37 AM »
thank you John,..Interesting.
Keep smile...

JohnK

  • Administrator
  • Seagull
  • Posts: 10646
Re: alternative to vl-directory-files
« Reply #6 on: December 08, 2015, 11:48:39 AM »
No problem. I know it may not be ideal but give it a try anyways.
TheSwamp.org (serving the CAD community since 2003)
Member location map - Add yourself

Donate to TheSwamp.org

pkohut

  • Bull Frog
  • Posts: 483
Re: alternative to vl-directory-files
« Reply #7 on: December 08, 2015, 04:09:18 PM »
This would need to be recompiled and tested with your version of Autocad. 
http://www.theswamp.org/index.php?topic=33994.msg393459#msg393459

Thank you guys,..
same test I've made..

question...is there any way to capture the DIR dos Value without putting the result in a txt file ?
I've made some research on the web but unfortunatly,..seem that I cannot find anything about it..

 :rolleyes2:
New tread (not retired) - public repo at https://github.com/pkohut

JohnK

  • Administrator
  • Seagull
  • Posts: 10646
Re: alternative to vl-directory-files
« Reply #8 on: December 08, 2015, 04:27:13 PM »
I had hoped you'd chime in with that tool, Paul. I had a mention of that in my original post but removed it before I posted. :)
TheSwamp.org (serving the CAD community since 2003)
Member location map - Add yourself

Donate to TheSwamp.org

pkohut

  • Bull Frog
  • Posts: 483
Re: alternative to vl-directory-files
« Reply #9 on: December 09, 2015, 02:18:51 AM »
Had a vague recollection of doing something with the shell and looked it up.  If OP is interested in using it, maybe someone could compile for him?

I had hoped you'd chime in with that tool, Paul. I had a mention of that in my original post but removed it before I posted. :)
New tread (not retired) - public repo at https://github.com/pkohut