首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Perl one-liner:从数组中删除路径,只获取路径中的姓氏,如basename

Perl one-liner: 从数组中删除路径, 只获取路径中的姓氏, 如 basename

要完成这个任务,您需要使用Perl编程语言。下面是一个Perl one-liner示例,用于从数组中删除路径,并只获取路径中的姓氏:

代码语言:perl
复制
@names = ("John Doe", "Jane Smith", "Bob Johnson", "Mary Johnson");
@without_path = map { $_->[1] } grep { !/^\// } @names;
print "@without_path\n";

这个示例代码首先定义了一个包含四个名字的数组。然后,使用mapgrep函数来过滤出路径中的姓氏。map函数将每个元素传递给$_->[1],这会导致仅保留第二个元素(姓氏)。grep函数会过滤出没有/符号的元素,从而保留路径。最后,使用print语句将结果输出到控制台。

请注意,这个示例假设姓氏在路径中。如果您的数据集有不同的结构,您可能需要对代码进行相应的修改。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

《Perl语言入门》——读书笔记

Perl语言入门 /** * prism.js Github theme based on GitHub's theme. * @author Sam Clarke */ code[class*="language-"], pre[class*="language-"] { color: #333; background: none; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; text-align: left; white-space: pre; word-spacing: normal; word-break: normal; word-wrap: normal; line-height: 1.4; -moz-tab-size: 8; -o-tab-size: 8; tab-size: 8; -webkit-hyphens: none; -moz-hyphens: none; -ms-hyphens: none; hyphens: none; } /* Code blocks */ pre[class*="language-"] { padding: .8em; overflow: auto; /* border: 1px solid #ddd; */ border-radius: 3px; /* background: #fff; */ background: #f5f5f5; } /* Inline code */ :not(pre) > code[class*="language-"] { padding: .1em; border-radius: .3em; white-space: normal; background: #f5f5f5; } .token.comment, .token.blockquote { color: #969896; } .token.cdata { color: #183691; } .token.doctype, .token.punctuation, .token.variable, .token.macro.property { color: #333; } .token.operator, .token.important, .token.keyword, .token.rule, .token.builtin { color: #a71d5d; } .token.string, .token.url, .token.regex, .token.attr-value { color: #183691; } .token.property, .token.number, .token.boolean, .token.entity, .token.atrule, .token.constant, .token.symbol, .token.command, .token.code { color: #0086b3; } .token.tag, .token.selector, .token.prolog { color: #63a35c; } .token.function, .token.namespace, .token.pseudo-element, .token.class, .token.class-name, .token.pseudo-class, .token.id, .token.url-reference .token.variable, .token.attr-name { color: #795da3; } .token.entity { cursor: help; } .token.title, .token.title .token.punctuation { font-weight: bold; color: #1d3e81; } .token.list { color: #ed6a43; } .token.inserted { background-color: #eaffea; color: #55a532; } .token.deleted { background-color: #ffecec; color: #bd2c00; } .token.bold { font-weight: bold; } .token.italic { font-style: italic; } /* JSON */ .lan

02

python 文件 目录操作

python中对文件、文件夹(文件操作函数)的操作需要涉及到os模块和shutil模块。 得到当前工作目录,即当前Python脚本工作的目录路径: os.getcwd() 返回指定目录下的所有文件和目录名:os.listdir() 函数用来删除一个文件:os.remove() 删除多个目录:os.removedirs(r“c:\python”) 检验给出的路径是否是一个文件:os.path.isfile() 检验给出的路径是否是一个目录:os.path.isdir() 判断是否是绝对路径:os.path.isabs() 检验给出的路径是否真地存:os.path.exists() 返回一个路径的目录名和文件名:os.path.split() eg os.path.split('/home/swaroop/byte/code/poem.txt') 结果:('/home/swaroop/byte/code', 'poem.txt') 分离扩展名:os.path.splitext() 获取路径名:os.path.dirname() 获取文件名:os.path.basename() 运行shell命令: os.system() 重命名:os.rename(old, new) 创建多级目录:os.makedirs(r“c:\python\test”) 创建单个目录:os.mkdir(“test”) 获取文件属性:os.stat(file) 修改文件权限与时间戳:os.chmod(file) 终止当前进程:os.exit() 获取文件大小:os.path.getsize(filename) getsize os.path.join(路径,文件) #################################### '/var/log/message' \>>> y=os.path.dirname(a) \>>> y '/var/log' \>>> b='message' \>>> aa=os.path.join(y,b) \>>> print aa /var/log/message ####################################

01

python 文件和路径操作函数小结

1: os.listdir(path) //path为目录  功能相当于在path目录下执行dir命令,返回为list类型  print os.listdir('..')  2: os.path.walk(path,visit,arg)  path :是将要遍历的目录  visit :是一个函数指针,函数圆形为:  callback(arg,dir,fileList)  其中arg为为传给walk的arg , dir是path下的一个目录,fileList为dir下的文件和目录组成的list, arg:传给visit用的  3:os.path.split(path)  path 为一个路径,  输出,把path分成两部分,具体看实例:  print os.path.split("abc/de.txt")  ('abc', 'de.txt')  os.path.split("abc")  (", 'abc')  print os.path.split("de/abc/de")  ('de/abc', 'de')  4: os.path.splitext(filename)  把文件名分成文件名称和扩展名  os.path.splitext(abc/abcd.txt)  ('abc/abcd', '.txt')  5: os.path.dirname(path)  把目录名提出来  print os.path.dirname("abc")  #输出为空  print os.path.dirname('abc\def')  abc  6: os.path.basename(filename)  取得主文件名  print os.path.basename('abc')  abc  print os.path.basename('abc.txt')  abc  print os.path.basename('bcd/abc')  abc #这个需要注意不包括目录名称  print os.path.basename('.')  .  7:os.mkdir(path, [mode])  path为目录名: 这里有个要求,只能创建一级目录  比如path为 abc/def 则当前目录下必须存在abc 否则失败  8: os.makedirs(path [,mode])  可以创建多级目录  9:os.remove(path)删除一个文件,一定是一个文件  os.removedirs(path) 删除一个目录下所有东西  os.rmdir(path) 删除一个目录,而且一定要空,否则os.errer  10:os.walk(path)  遍历path,返回一个对象,他的每个部分都是一个三元组  ('目录x',[目录x下的目录list],目录x下面的文件)  举例:  a = os.walk('.')  for i in a:  print i  11:shutil.copy(src,dst)  把文件src内容拷贝到文件dst中。,目标区域必须可以写,如果dst存在,则dst被覆盖  ――――――――――――――――――  11.1 os.path -- 普通的路径名操作  这个模块实现一些在路径名称上有用的函数。  警告:在 Windows 上,这些函数中的多个不能正确地支持 UNC 路径名。splitunc() 和 ismount() 可以正确地处理它们。  abspath(path)  返回 path 路径名一个规格化的绝对化的版本。在大多数平台上,相当于normpath(join(os.getcwd(), path))。1.5.2版本中的新特性。  basename(path)  返回 path 路径名最底部的名称。这是由 split(path)返回的对的第二半部分。注意这个函数的结果不同于Unix basename 程序;UNIX的 basename对于'/foo/bar/' 返回 'bar',basename() 函数返回一个空字符串('')。  commonprefix(list)  返回最长的路径前缀(采取字符的字符),是 list中所有路径的一个前缀。如果 list 为空,返回空字符串('')。注意可以返回无效的路径因为它每次操作一个字符。  dirname(path)  返回 path 路径名的目录名称。这是由 split(path)返回的对的第一半部分。  exists(path)  如果 path 与一个已存在的路径关联返回True。对于损坏的符号连接返回 False 。在一些平台上,如果权限没有被授予在请求的文件上执行os.stat()这个函数可能返回False,即使该 path 实际上存在。  lexists(path)  如果 path 与一个已存在的路径关联返回 True 。对于损坏的连接返回 True

02
领券