与na.action = na.pass聚合会给出意想不到的答案

时间:2015-11-18 15:21:44

标签: r aggregate na

我使用以下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中完成我想要的东西?任何帮助将不胜感激。

1 个答案:

答案 0 :(得分:7)

aggregate使用tapplyfactor反过来在其分组变量上使用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);
}