Tillbaka till svenska Fidonet
English   Information   Debug  
HUMOR   0/29
IC   0/2851
INTERNET   0/424
INTERUSER   0/3
IP_CONNECT   719
JAMNNTPD   0/233
JAMTLAND   0/47
KATTY_KORNER   0/41
LAN   0/16
LINUX-USER   0/19
LINUXHELP   0/1155
LINUX   0/22112
LINUX_BBS   0/957
mail   18.68
mail_fore_ok   249
MENSA   0/341
MODERATOR   0/102
MONTE   0/992
MOSCOW_OKLAHOMA   0/1245
MUFFIN   0/783
MUSIC   0/321
N203_STAT   930
N203_SYSCHAT   313
NET203   321
NET204   69
NET_DEV   0/10
NORD.ADMIN   0/101
NORD.CHAT   0/2572
NORD.FIDONET   189
NORD.HARDWARE   0/28
NORD.KULTUR   0/114
NORD.PROG   0/32
NORD.SOFTWARE   0/88
NORD.TEKNIK   0/58
NORD   0/453
OCCULT_CHAT   0/93
OS2BBS   0/787
OS2DOSBBS   0/580
OS2HW   0/42
OS2INET   0/37
OS2LAN   0/134
OS2PROG   0/36
OS2REXX   0/113
OS2USER-L   207
OS2   0/4786
OSDEBATE   0/18996
PASCAL   0/490
PERL   0/457
PHP   0/45
POINTS   0/405
POLITICS   0/29554
POL_INC   0/14731
PSION   103
R20_ADMIN   1123
R20_AMATORRADIO   0/2
R20_BEST_OF_FIDONET   13
R20_CHAT   0/893
R20_DEPP   0/3
R20_DEV   399
R20_ECHO2   1379
R20_ECHOPRES   0/35
R20_ESTAT   0/719
R20_FIDONETPROG...
...RAM.MYPOINT
  0/2
R20_FIDONETPROGRAM   0/22
R20_FIDONET   0/248
R20_FILEFIND   0/24
R20_FILEFOUND   0/22
R20_HIFI   0/3
R20_INFO2   3249
R20_INTERNET   0/12940
R20_INTRESSE   0/60
R20_INTR_KOM   0/99
R20_KANDIDAT.CHAT   42
R20_KANDIDAT   28
R20_KOM_DEV   112
R20_KONTROLL   0/13300
R20_KORSET   0/18
R20_LOKALTRAFIK   0/24
R20_MODERATOR   0/1852
R20_NC   76
R20_NET200   245
R20_NETWORK.OTH...
...ERNETS
  0/13
R20_OPERATIVSYS...
...TEM.LINUX
  0/44
R20_PROGRAMVAROR   0/1
R20_REC2NEC   534
R20_SFOSM   0/341
R20_SF   0/108
R20_SPRAK.ENGLISH   0/1
R20_SQUISH   107
R20_TEST   2
R20_WORST_OF_FIDONET   12
RAR   0/9
RA_MULTI   106
RA_UTIL   0/162
REGCON.EUR   0/2056
REGCON   0/13
SCIENCE   0/1206
SF   0/239
SHAREWARE_SUPPORT   0/5146
SHAREWRE   0/14
SIMPSONS   0/169
STATS_OLD1   0/2539.065
STATS_OLD2   0/2530
STATS_OLD3   0/2395.095
STATS_OLD4   0/1692.25
SURVIVOR   0/495
SYSOPS_CORNER   0/3
SYSOP   0/84
TAGLINES   0/112
TEAMOS2   0/4530
TECH   0/2617
TEST.444   0/105
TRAPDOOR   0/19
TREK   0/755
TUB   0/290
UFO   0/40
UNIX   0/1316
USA_EURLINK   0/102
USR_MODEMS   0/1
VATICAN   0/2740
VIETNAM_VETS   0/14
VIRUS   0/378
VIRUS_INFO   0/201
VISUAL_BASIC   0/473
WHITEHOUSE   0/5187
WIN2000   0/101
WIN32   0/30
WIN95   0/4289
WIN95_OLD1   0/70272
WINDOWS   0/1517
WWB_SYSOP   0/419
WWB_TECH   0/810
ZCC-PUBLIC   0/1
ZEC   4

 
4DOS   0/134
ABORTION   0/7
ALASKA_CHAT   0/506
ALLFIX_FILE   0/1313
ALLFIX_FILE_OLD1   0/7997
ALT_DOS   0/152
AMATEUR_RADIO   0/1039
AMIGASALE   0/14
AMIGA   0/331
AMIGA_INT   0/1
AMIGA_PROG   0/20
AMIGA_SYSOP   0/26
ANIME   0/15
ARGUS   0/924
ASCII_ART   0/340
ASIAN_LINK   0/651
ASTRONOMY   0/417
AUDIO   0/92
AUTOMOBILE_RACING   0/105
BABYLON5   0/17862
BAG   135
BATPOWER   0/361
BBBS.ENGLISH   0/382
BBSLAW   0/109
BBS_ADS   0/5290
BBS_INTERNET   0/507
BIBLE   0/3563
BINKD   0/1119
BINKLEY   0/215
BLUEWAVE   0/2173
CABLE_MODEMS   0/25
CBM   0/46
CDRECORD   0/66
CDROM   0/20
CLASSIC_COMPUTER   0/378
COMICS   0/15
CONSPRCY   0/899
COOKING   33421
COOKING_OLD1   0/24719
COOKING_OLD2   0/40862
COOKING_OLD3   0/37489
COOKING_OLD4   0/35496
COOKING_OLD5   9370
C_ECHO   0/189
C_PLUSPLUS   0/31
DIRTY_DOZEN   0/201
DOORGAMES   0/2065
DOS_INTERNET   0/196
duplikat   6002
ECHOLIST   0/18295
EC_SUPPORT   0/318
ELECTRONICS   0/359
ELEKTRONIK.GER   1534
ENET.LINGUISTIC   0/13
ENET.POLITICS   0/4
ENET.SOFT   0/11701
ENET.SYSOP   33945
ENET.TALKS   0/32
ENGLISH_TUTOR   0/2000
EVOLUTION   0/1335
FDECHO   0/217
FDN_ANNOUNCE   0/7068
FIDONEWS   24159
FIDONEWS_OLD1   0/49742
FIDONEWS_OLD2   0/35949
FIDONEWS_OLD3   0/30874
FIDONEWS_OLD4   0/37224
FIDO_SYSOP   12852
FIDO_UTIL   0/180
FILEFIND   0/209
FILEGATE   0/212
FILM   0/18
FNEWS_PUBLISH   4436
FN_SYSOP   41706
FN_SYSOP_OLD1   71952
FTP_FIDO   0/2
FTSC_PUBLIC   0/13613
FUNNY   0/4886
GENEALOGY.EUR   0/71
GET_INFO   105
GOLDED   0/408
HAM   0/16074
HOLYSMOKE   0/6791
HOT_SITES   0/1
HTMLEDIT   0/71
HUB203   466
HUB_100   264
HUB_400   39
Möte LINUXHELP, 1155 texter
 lista första sista föregående nästa
Text 1040, 119 rader
Skriven 2006-12-22 13:11:22 av David Calafrancesco (1:2624/306.0)
   Kommentar till text 1035 av Randall Parker (1:379/45)
Ärende: Recursive ls on book*.*?
================================
Randall Parker wrote in a message to John Beckett:

 RP> From: Randall Parker
 RP> <future_take-out-this-stuff_pundit@_same-name-as-on-left-s
 RP> ide_dot-here_com>

 RP> John Beckett wrote:
> You've had some informative replies, but they have not mentioned one vital
> point. If Unix had a 'dir /s' command, the above would still not do what
> you want because Unix has no concept of a file extension.

 RP> Suppose one wants to find, say, book*.html. How hard is it to do
 RP> that? 

Trivially easy. There has been a lot ignored that needs to be stated here. 

First, like DOS/OS2, Linux and Unix have the concept of the current directory
and the parent directory. They even use the same conventions in all four OS
enviornments, . is the current directory and .. is the parent directory. With
that stated, any command that can take a path can accept the current directory
via a . and the parent directory via the .. You can then start referencing
further directories from there. 

The next thing that hasn't been stated is the concept of case sensitivity. In
Windows/OS2 it generally doesn't exist. However in Linux and Unix it is
extremely case sensitive. 

In addition, Linux web servers are very tolerant in regards to what form their
file names take. They can be tagged .html, they can also be tagged .htm and
they can even be upper case to allow people to upload files from braindead
systems like Windows to a real web server. 

Lastly, nobody has touched on the biggest strength of the Linux and Unix shell
systems, that of concatenating commands together using pipes and redirections. 

If I wanted to find all web pages that contained the word book starting at the
current directory I would instantly use the following command: 

find . -type f | grep -i book.*\.htm? 

If however I wanted only those files that had the 'book' starting at the
beginning of the filename. I would change the above as follows: 

find . -type f | grep -i \/book.*\.htm[l]$

Note that the backslash is the RegExp escape character to allow the search to
actually find a period or forward slash. The period is generally replaced with
zero or one occurance of any character. The * says to repeat the previous
character as many times as possible given the constraints of the rest of the
search. The [l] says it can be replaced with an l character optionally. The $
says the search term needs to end on the end of the line. The -i says to ignore
case when searching. 





> The pattern book*.*
> matches only file names starting with 'book' AND
> that contain a period (".") after 'book'.
>
> As was mentioned, you need pattern book* (no period).

 RP> So find is the command to use unless you have an up-to-date
 RP> database for locate? 

> The action "-print" is usually the default, so the equivalent of
> DOS 'dir /s book*.*' is
> find . -name "book*"

 RP> This seems verbose. But the -name applies to what comes after it,
 RP> right? So how could one create an alias or script that would just
 RP> take a path and a string? e.g.:

 RP> ff . "book*"

That depends on whether you want to ignore case and whether you want any file
that has book at the beginning of the filename or anywhere in the file name. To
be truly flexible I'd write the alias so that it depended on a regular
expression being passed in as the search term. In all of the previous, it was
implied you were looking for only files, though all of the example find
commands would have turned up all occurances of directories named book* that
were located below current dir. The -type f in the find command will limit the
search to only files. 

#!/bin/bash
find $1 -type f | grep $2 

>
> The '.' refers to the current directory. Use '/' to start from root.
>
> When I last investigated 'find' (a couple of years ago), I discovered that
> you should use 'locate' or better still 'slocate'. These are much faster,
> but depend on an index file being maintained.

 RP> So how to update the database for locate and slocate?

Locate doesn't search as far as find does. It is limited to only those paths
that it is told to build a database for. Find has no such limits. If you have
mounted other file systems, find will happily follow them to their depths,
unless you have told it to limit itself to only a single file system. 


>
> I think that 'find' is strictly case sensitive, whereas 'slocate' has an
> option for case insensitive searching.

Find piped to grep is a combinaion that is infinitely powerful. 

My advice to anyone learning the linux or unix shells, is to experiment and
learn the art of concatenation of commands. It will serve you well for the rest
of your life. 

Dave Calafrancesco, Team OS/2
dave@drakkar.org

... They got the library at Alexandria, they're not getting mine! 
--- 
 * Origin: Druid's Grove BBS - telnet:bbs.drakkar.org (1:2624/306)