我使用以下data.frame作为示例:
d <- data.frame(x=c(1,NA), y=c(2,3))
我想用变量x来总结y的值。由于没有x的共同值,我希望聚合只是给我原始的data.frame back,其中NA被视为一个组。但聚合给了我以下结果。
>aggregate(y ~ x, data=d, FUN=sum)
x y
1 1 2
我已经阅读了有关更改na.action默认操作的文档,但它似乎没有给我任何有意义的信息。
>aggregate(y ~ x, data=d, FUN=sum, na.action=na.pass)
x y
1 1 2
发生了什么事?我似乎不明白na.pass在这种情况下做了什么。有没有选择在R中完成我想要的东西?任何帮助将不胜感激。
答案 0 :(得分:7)
aggregate
使用tapply
,factor
反过来在其分组变量上使用NA
。
但是,请查看factor
中的factor(c(1, 2, NA))
# [1] 1 2 <NA>
# Levels: 1 2
值会发生什么:
levels
请注意addNA
。您可以使用NA
来保留addNA(factor(c(1, 2, NA)))
# [1] 1 2 <NA>
# Levels: 1 2 <NA>
:
aggregate(y ~ addNA(x), d, sum)
# addNA(x) y
# 1 1 2
# 2 <NA> 3
因此,您可能需要执行以下操作:
d$x <- addNA(factor(d$x))
str(d)
# 'data.frame': 2 obs. of 2 variables:
# $ x: Factor w/ 2 levels "1",NA: 1 2
# $ y: num 2 3
aggregate(y ~ x, d, sum)
# x y
# 1 1 2
# 2 <NA> 3
或类似的东西:
aggregate
(或者,升级为“data.table”,这不仅比NA
更快,而且还会为library(data.table)
as.data.table(d)[, sum(y), by = x]
# x V1
# 1: 1 2
# 2: NA 3
值提供更一致的行为。不需要要注意你是否using the formula method of aggregate
or not。)
btnCamera.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Intent cameraIntent = new Intent(android.provider.MediaStore.ACTION_IMAGE_CAPTURE);
startActivityForResult(cameraIntent, CAMERA_REQUEST);
}
});
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
if (requestCode == CAMERA_REQUEST && resultCode == RESULT_OK) {
Bitmap photo = (Bitmap) data.getExtras().get("data");
Uri tempUri = getImageUri(getApplicationContext(), photo);
String ruta = getRealPathFromURI(tempUri);
Intent i = new Intent(getApplicationContext(), WarikeActivity.class);
i.putExtra("ruta",ruta);
startActivity(i);
}
}
public Uri getImageUri(Context inContext, Bitmap inImage) {
ByteArrayOutputStream bytes = new ByteArrayOutputStream();
inImage.compress(Bitmap.CompressFormat.JPEG, 100, bytes);
String path = MediaStore.Images.Media.insertImage(inContext.getContentResolver(), inImage, "Title", null);
return Uri.parse(path);
}
public String getRealPathFromURI(Uri uri) {
Cursor cursor = getContentResolver().query(uri, null, null, null, null);
cursor.moveToFirst();
int idx = cursor.getColumnIndex(MediaStore.Images.ImageColumns.DATA);
return cursor.getString(idx);
}