将文件名拆分为名称,扩展名

r split substring filenames

24992 观看

3回复

2124 作者的声誉

我有这样一个文件的名称:name1.csv我想提取这个字符串的两个子串。一个存储name1一个变量,另一个存储扩展csv,而不存在另一个变量中的点。

我一直在寻找是否有类似indexOfJava 的功能允许进行那种操作,但我还没有找到任何东西。

有帮助吗?

作者: Layla 的来源 发布者: 2013 年 1 月 5 日

回应 3


57

288648 作者的声誉

决定

用途strsplit

R> strsplit("name1.csv", "\\.")[[1]]
[1] "name1" "csv"  
R> 

请注意,a)需要转义点(因为它是正则表达式的元字符)和b)处理strsplit()返回列表的事实,该列表通常只有第一个元素是感兴趣的。

更通用的解决方案涉及正则表达式,您可以在其中提取匹配项。

对于文件名的特殊情况,您还有:

R> library(tools)   # unless already loaded, comes with base R
R> file_ext("name1.csv")
[1] "csv"
R> 

R> file_path_sans_ext("name1.csv")
[1] "name1"
R> 

因为这些是如此常见的任务(参见basenameshell等)。

作者: Dirk Eddelbuettel 发布者: 2013 年 1 月 5 日

7

15748 作者的声誉

用途strsplit()

http://stat.ethz.ch/R-manual/R-devel/library/base/html/strsplit.html

例:

> strsplit('name1.csv', '[.]')[[1]]
[1] "name1" "csv"  

请注意,第二个参数是正则表达式,这就是为什么你不能只传递单个点(它将被解释为“任何字符”)。

作者: Adam Stelmaszczyk 发布者: 2013 年 1 月 5 日

2

101625 作者的声誉

使用正则表达式,您可以执行此操作

regmatches(x='name1.csv',gregexpr('[.]','name1.csv'),invert=TRUE)
[[1]]
[1] "name1" "csv"  
作者: agstudy 发布者: 2013 年 1 月 5 日
32x32