我的knitr文档中的特殊字符有问题。普通文本工作正常,但图片上标题或轴名称中的抛光字母没有。
我试图通过安装cairoDevice包来解决这个问题。但它仍然无效。实际上我不确定这个包是否正常工作,因为我还必须安装Rgtk2包,并且它也存在问题。除了cairoDevice之外还有其他任何方式来获取信件吗?如果不是如何让它正常工作?
这是我的knitr文件problem.Rnw
:
\documentclass[12 pt, a4paper]{article}
\usepackage[T1]{fontenc}
\usepackage[utf8]{inputenc}
\usepackage{polski}
\usepackage{geometry}
\geometry{total={210mm, 297mm}, left=17mm, right=17mm, top=17mm, bottom=17mm}
\usepackage[font=footnotesize,labelfont=bf]{caption}
\usepackage{url}
\usepackage[colorlinks=true]{hyperref}
\hypersetup{linkcolor=blue}
<<include=F>>=
source("My path/plot.R")
@
<<include=F>>=
library(knitr)
library(RGtk2)
library(Cairo)
library(cairoDevice)
#ustawienia globalne
opts_chunk$set(fig.path='figure/', fig.align='center', fig.show='asis', fig.pos='ht!', dev='CairoPDF')
@
\begin{document}
<<MusicBad, echo=F, fig.width=5, fig.height=5, out.width='.5\\linewidth', fig.cap='Błędne zastosowanie wykresu liniowego.'>>=
plot.music.bad
@
\end{document}
这里是我的plot.R
文件:
library(ggplot2)
#create data frame
music <- c("Blues", "Hip-hop", "Jazz", "Metal", "Rock")
number <- c(8, 7, 4, 6, 11)
df.music <- data.frame(music, number)
#create line graph
plot.music.bad <- ggplot(data=df.music, aes(x=music, y=number, group=1)) +
geom_line(size=1, color="#333333") +
geom_point(size=3, color="#333333") +
xlab("Rodzaj muzyki") +
ylab("Liczba studentów") +
ylim(c(0,11)) +
ggtitle("Ulubiony typ muzyki wśród studentów")
你知道怎么做吗?我只想在图形中加入抛光字母。谢谢。
EDIT 我的sessioninfo:
sessionInfo()
R version 2.15.3 (2013-03-01)
Platform: x86_64-w64-mingw32/x64 (64-bit)
locale:
[1] LC_COLLATE=Polish_Poland.1250 LC_CTYPE=Polish_Poland.1250
[3] LC_MONETARY=Polish_Poland.1250 LC_NUMERIC=C
[5] LC_TIME=Polish_Poland.1250
attached base packages:
[1] stats graphics grDevices utils datasets methods base
loaded via a namespace (and not attached):
[1] tools_2.15.3
如果我从控制台运行此图,它可以正常工作。我将其保存为pdf时遇到了同样的问题,但是如果我运行cairo_pdf(name, width=width, height=height)
而不是pdf(name, width=width, height=height)
,则会保存为特殊字符。
答案 0 :(得分:0)
你应该在开头改变编码:
<<result='hide'>>=
Sys.setlocale('LC_CTYPE', 'pl_PL.UTF-8')
@