URN Logo
UNIX Resources » Linux » China Linux Forum » Perl 编 程 » 3 » 请问如何去掉文本中重复的内容?
announcement 声明: 本页内容为中国Linux论坛的内容镜像,文章的版权以及其他所有的相关权利属于中国Linux论坛和相应文章的作者,如果转载,请注明文章来源及相关版权信息。
Resources
China Linux Forum(finished)
Linux Forum(finished)
FreeBSD China(finished)
linuxforum.net
  业界新闻与评论
  自由软件杂谈
  IT 人生
  Linux软件快递
  翻译作坊
  Linux图书与评论
  GNU Emacs/XEmacs
  Linux 中文环境和中文化
  Linux桌面与办公软件
  Linux 多媒体与娱乐版
  自由之窗Mozilla
  笔记本电脑上的Linux
  Gentoo
  Debian 一族
  网络管理技术
  Linux 安装与入门
  WEB服务器和FTP服务器
  域名服务器和邮件服务器
  Linux防火墙和代理服务器应用
  文件及打印服务器
  技术培训与认证
  Linux内核技术
  Linux 嵌入技术
  Linux设备驱动程序
  Linux 集群技术
  LINUX平台数据库
  系统和网络安全
  CPU 与 编译器
  系统计算研究所专栏
  Linux下的GUI软件开发
  C/C++编程版
  PHP 技 术
  Java&jsp技术
  Shell编程技术
  Perl 编 程
  Python 编 程
  XML/Web Service 技术
  永远的Unix
  FreeBSD世界
   
请问如何去掉文本中重复的内容?
请问如何去掉文本中重复的内容? - sharkman [2005-04-19 01:38 | 1,100 byte(s)]
 
 
 
 
 
 
 
 
 
 
Subject: 请问如何去掉文本中重复的内容?
Author: sharkman    Posted: 2005-04-19 01:38    Length: 1,100 byte(s)
[Original] [Print] [Top]
就是这么个事情:

一个txt吧,里面一行一行的,有重复的行,想把重复的变成一个,应该怎么写?

my $readfile = "readfile.txt";

my $writefile = "writefile.txt";


print "请输入本次要处理的行数:";
my $b = <STDIN>;
chomp $b;




if (open (readfile,"$readfile") || die ("can not open readfile")){

@line = <readfile>;


}


for (my $a = 0 ; $a <= $b-1 ; $a++ ){
my $e = $a+1;

print "共要处理$b个,且第$e个正在进行 ";



if (open (writefile,">>$writefile") || die ("can not open writefile")){

怎么写?

print writefile 怎么写?;

}


}

[Original] [Print] [Top]
Subject: Re: 请问如何去掉文本中重复的内容?
Author: DanceDanceDance    Posted: 2005-04-19 15:15    Length: 41 byte(s)
[Original] [Print] [Top]
可以利用hash的key的唯一性来解决这个问题。
----
It's better to burn out than to fade away...
[Original] [Print] [Top]
Subject: Re: 请问如何去掉文本中重复的内容?
Author: sharkman    Posted: 2005-04-19 16:33    Length: 99 byte(s)
[Original] [Print] [Top]
hash的key的唯一性..................把@line = <file>;的@line都搞到hash里去?这句咋写?
[Original] [Print] [Top]
Subject: Re: 请问如何去掉文本中重复的内容?
Author: sharkman    Posted: 2005-04-19 17:53    Length: 698 byte(s)
[Original] [Print] [Top]
这么写确实去掉了几行,但是还是不对啊

my $readfile = "readfile.txt";

my $writefile = "writefile.txt";




if (open (readfile,"$readfile") || die ("can not open readfile")){

@line = <readfile>;


}

%lines = @line;


if (open (writefile,">>$writefile") || die ("can not open writefile")){


@this = %lines;
print writefile ("@this");


}
[Original] [Print] [Top]
Subject: Re: 请问如何去掉文本中重复的内容?
Author: wandys    Posted: 2005-04-19 21:18    Length: 175 byte(s)
[Original] [Print] [Top]
my %line;

while (<>) {
next if exists $line{$_};
$line{$_} = 1;
print;
}
----
UN*X is user^H^H^H^Hfriend-friendly.
[Original] [Print] [Top]
Subject: Re: 请问如何去掉文本中重复的内容?
Author: sharkman    Posted: 2005-04-19 22:03    Length: 22 byte(s)
[Original] [Print] [Top]
啊?怎么怎么就=1了??
[Original] [Print] [Top]
Subject: Re: 请问如何去掉文本中重复的内容?
Author: DanceDanceDance    Posted: 2005-04-19 22:30    Length: 57 byte(s)
[Original] [Print] [Top]
这类用法可以称为Perl的"idiom",非常的简洁明了。
----
It's better to burn out than to fade away...
[Original] [Print] [Top]
Subject: Re: 请问如何去掉文本中重复的内容?
Author: sharkman    Posted: 2005-04-20 00:57    Length: 17 byte(s)
[Original] [Print] [Top]
>_<
[Original] [Print] [Top]
Subject: Re: 请问如何去掉文本中重复的内容?
Author: horsley    Posted: 2005-08-21 19:56    Length: 98 byte(s)
[Original] [Print] [Top]
这个不需要perl,shell 就行了,一句话:

cat filename |sort -u >newfilename
[Original] [Print] [Top]
Subject: Re: 请问如何去掉文本中重复的内容?
Author: yulongcn    Posted: 2007-12-10 17:15    Length: 8 byte(s)
[Original] [Print] [Top]
uniq就行
[Original] [Print] [Top]
« Previous thread
perlTk中如何使用XIM?
Perl 编 程
3
Next thread »
一个文件中,即有gb 编码也有utf编码。。
     

Copyright © 2007 UNIX Resources Network, All Rights Reserved.      About URN | Privacy & Legal | Help | Contact us
备案序号: 京ICP备05006143    webmaster: webmaster@unixresources.net
This page created on 2008-07-17 04:08:55, cost 0.053424835205078 ms.