factor(变量)
因子类型的转化
data:image/s3,"s3://crabby-images/f4fae/f4fae081123ecbce0267605c9b0dcce017c741ba" alt=""
R语言绘图
使用ggplot2绘图
导入依赖
library(ggplot2)
绘制柱状图
> mtcars$gear
[1] 4 4 4 3 3 3 3 4 4 4 4 3 3 3 3 3 3 4 4 4 3 3 3 3 3 4 5 5 5 5 5 4
> class(mtcars$gear)
[1] "numeric"
> barplot(mtcars$gear)
data:image/s3,"s3://crabby-images/1f58c/1f58c579875b996309809a1e4f85d1299b16e904" alt=""
- 统计一组数中元素的情况
> table(mtcars$gear)
3 4 5
15 12 5
> counts = table(mtcars$gear)
> barplot(counts)
data:image/s3,"s3://crabby-images/f4400/f4400d141b75ef05cee55dd272b419aad06a4b7f" alt=""
添加横坐标标签和定义柱状图颜色
> barplot(counts, names.arg = c("3 gears","4 gears", "5 挡"))
> barplot(counts, names.arg = c("3 gears","4 gears", "5 挡"), col="red")
> barplot(counts, names.arg = c("3 gears","4 gears", "5 挡"), col="lightblue")
> barplot(counts, names.arg = c("3 gears","4 gears", "5 挡"), col="pink")
data:image/s3,"s3://crabby-images/2d60b/2d60b1bf6d59e23ecc8d3ee4e7bbff98e477f911" alt=""
标签显示变成竖直
> par(las=2)
> barplot(counts, names.arg = c("3 gears","4 gears", "5 挡"), col="pink")
data:image/s3,"s3://crabby-images/6035c/6035cd5595128130acbcf1949ef569037522ed87" alt=""
多个条状图绘制
data:image/s3,"s3://crabby-images/8d509/8d5098817b03daae88771f16df4a0718a85f5870" alt=""
上面这样没有图例很难辨认数据的情况
指定字段绘制图形
> counts1 = table(mtcars$cyl, mtcars$gear)
> counts1
3 4 5
4 1 8 2
6 2 4 1
8 12 0 2
> barplot(counts1, names.arg = c("3 gears","4 gears", "5 gears"), col=c("pink", "blue", "yellow"),legend=rownames(counts1))
> rownames(counts1)
[1] "4" "6" "8"
data:image/s3,"s3://crabby-images/6462d/6462d8dfc7cca3b4da311abec60b427bf50f676e" alt=""
自定义图例 传入一个向量
> barplot(counts1, names.arg = c("3 gears","4 gears", "5 gears"), col=c("pink", "blue", "yellow"),legend=c("4 cyl", "6 cyl","8 cyl"))
data:image/s3,"s3://crabby-images/3ee9d/3ee9dfaa5135a35db6a0e5569f107a530157f513" alt=""
指定 beside = TRUE
> barplot(counts1, names.arg = c("3 gears","4 gears", "5 gears"), col=c("pink", "blue", "yellow"),legend=c("4 cyl", "6 cyl","8 cyl"), beside = TRUE)
data:image/s3,"s3://crabby-images/fb0f5/fb0f55fdba715e25f53152410c89d62000b5b138" alt=""
ggplot绘图"套路"
> ggplot(mtcars) # ggplot函数没有任何显示, 这里只是做数据集等准备操作
> p = ggplot(mtcars)
> p + geom_bar()
错误: stat_count() requires an x or y aesthetic.
Run `rlang::last_error()` to see where the error occurred.
> p = ggplot(mtcars, aes(x=factor(cyl))) #指定 cyl为横坐标
> p + geom_bar()
data:image/s3,"s3://crabby-images/c58ba/c58ba75bd1aeee7d0b4c4ed9a340b39c420701cf" alt=""
data:image/s3,"s3://crabby-images/67f3c/67f3cb553b421e2c80f907b6f08b24fd16be8441" alt=""
更换数据集mpg绘图
data:image/s3,"s3://crabby-images/1e952/1e952ef64c6f5a0379e93f94e536792e1494afed" alt=""
> p1 = ggplot(mpg, aes(class))
> aes(class)
Aesthetic mapping:
* `x` -> `class`
> table(mpg$class)
2seater compact midsize minivan pickup subcompact suv
5 47 41 11 33 35 62
> p1 + geom_bar()
data:image/s3,"s3://crabby-images/1eab9/1eab95dc17b3c1d4320cae5c6ead1bc5931f87ff" alt=""
p1 = ggplot(mpg, aes(class))
# p1 + geom_bar(aes(weight=displ))
p1 + geom_bar(aes(weight=year)) # 这里是属于这类所有值的相加
data:image/s3,"s3://crabby-images/fbc7b/fbc7bfc05b6188b627cee3e4e08eba5922dfb30a" alt=""
双重条形图
p1 = ggplot(mpg, aes(class))
p1 + geom_bar(aes(fill= drv)) # fill 是让ggplot自动根据因子的水平分数分配颜色等值
data:image/s3,"s3://crabby-images/10f28/10f2868d1867fa888035925fed7866dfc15ed2f6" alt=""
指定为水平条状图
p1 = ggplot(mpg, aes(class))
# p1 + geom_bar(aes(fill= drv)) # fill 是让ggplot自动根据因子的水平分数分配颜色等值
# 水平
p1 + geom_bar(aes(fill= drv), position = position_stack(reverse = TRUE))+ coord_flip() + theme(legend.position = "bottom")
data:image/s3,"s3://crabby-images/d4bb6/d4bb64594b51fcdeceb275bd3f6cb39a12b0600c" alt=""
直方图
> hist(mtcars$wt)
data:image/s3,"s3://crabby-images/dc6d7/dc6d735071d6a06c0efc8766bce79c75583e8a27" alt=""
# 变成总面积为1的概率分布直方图
> hist(mtcars$wt, freq = F)
data:image/s3,"s3://crabby-images/32eb6/32eb64f9b1f35475b460db620c7a3827edde9c77" alt=""
直方图参数增加
br 横坐标刻度范围 xlab横轴标签 main是标题
hist(mtcars$wt, freq = F, br=seq(0, 6, by =0.5),col = 'red', xlab = 'weight of cars', main = '车重直方图')
举一反三
> barplot(mtcars$wt, xlab = "车的重量", ylab = "数量", main = "数据标题", col = 'yellow')
data:image/s3,"s3://crabby-images/a44c0/a44c0927d729fc21f8b7573616675ceafacd906b" alt=""
网友评论