当我使用包exams来生成问题时,即使使用特殊字符,我也可以用英语完美地完成。例如,我可以使用考试包编译的Rnw问题:
<<echo=FALSE, results=hide>>=
## DATA GENERATION
P <- round(runif(n = 1, min = 1000, max = 2000), digits = 2)
S <- round(runif(n = 1, min = P + 500, max = 3000), digits = 2)
## QUESTION/ANSWER GENERATION
i <- round((S - P)/P, digits = 2)*100
@
\begin{question}
Qual \'e a taxa de juros simples obtida por uma aplica\c{c}\~ao de \textdollar $\Sexpr{P}$ que, ap\'os um ano, produz um montante de \textdollar$\Sexpr{S}$?
\end{question}
\begin{solution}
Os juros s\~ao calculados por:
\begin{equation}
S = P(1+i \times n) \Rightarrow S = P + Pin \Rightarrow
\end{equation}
\begin{equation}
Pin = S - P \Rightarrow
i = \frac{S-P}{Pn} \Rightarrow i = \frac{S-P}{P}
\end{equation}
O valor absotulo dos juros \'e $\Sexpr{i}$\%.
\end{solution}
%% META-INFORMATION
%% \extype{num}
%% \exsolution{\Sexpr{fmt(abs(tstat), 3)}}
%% \exname{t statistic}
%% \extol{0.01}
例如,当我需要ç时,我只使用\ c {c}等等。但是,我一直在尝试使用Rmarkdown而不是Rnw文件。 Rmd中的相同示例:
---
output: pdf_document
---
```{r data generation, echo = FALSE, results = "hide"}
P <- round(runif(n = 1, min = 1000, max = 2000), digits = 2)
S <- round(runif(n = 1, min = P + 500, max = 3000), digits = 2)
i <- round((S - P)/P, digits = 2)*100
```
Question
========
Qual é a taxa de juros simples obtida por uma aplicação de $`r P`
Solution
========
Os juros são calculados por:
\begin{equation}
S = P(1+i \times n) \Rightarrow S = P + Pin \Rightarrow
\end{equation}
\begin{equation}
Pin = S - P \Rightarrow
i = \frac{S-P}{Pn} \Rightarrow i = \frac{S-P}{P}
\end{equation}
O valor absotulo dos juros é `r i`%.
Meta-information
================
extype: num
exsolution: `r round(i, digits = 3)`
exname: Euclidean distance
extol: 0.01
我可以用RStudio编译正确显示重音:
但是当我尝试时:
exams2pdf('file.Rmd', encoding = 'utf8')
它不起作用。
有人可以帮我解决这个问题吗?
答案 0 :(得分:5)
我尝试了header
的{{1}}和inputs
的参数的不同方法,但没有一个给我正确的输出。通过YAML标头(exams2pdf()
)添加LaTeX命令也不起作用。所以我采用了这种方式&#34;
转到R库,找到保存包考试的位置。在里面导航到tex文件夹。在那里,您将找到考试使用的不同模板。创建默认模板 plain.tex 的副本,并将其重命名为 plain_pt.tex 。在该文件中添加
header-includes
到序言。保存文件。
我的OSX机器上的完整路径:
\usepackage[utf8]{inputenc}
\usepackage[T1]{fontenc}
\usepackage[portuguese]{babel}
在Linux中可以是:
/Library/Frameworks/R.framework/Versions/3.3/Resources/library/exams/tex
现在,在致电~/R/x86_64-pc-linux-gnu-library/3.3/Resources/library/exams/tex
时,您可以选择exams2pdf
的新模板。
通过添加适当的LaTeX命令,这也适用于其他语言。
答案 1 :(得分:2)
感谢@MartinDabbelJuSmelter的回复,它基本上捕获了正在发生的事情。但是,有更简单的解决方案。最简单的是:
exams2pdf("file.Rmd", encoding = "UTF-8", template = "plain8")
导致所需的输出。现在为什么这么复杂,为什么记录如此糟糕?
由于exams
包的模块化结构,它很复杂。有很多不同的方法来组合不同的构建块,这很容易,这需要两个参数。首先,您必须声明file.Rmd
位于encoding
UTF-8中。其次,您必须使用支持UTF-8的template
。 exams
软件包附带一个简单的plain
模板,启用了UTF-8。
在不同的编码等中没有更多的LaTeX模板,因为我们预计几乎所有用户都会想要使用他们自己的自定义模板。例如,要显示其大学或其课程的名称或使用特定的样式/字体/等。
如果您只有单选(schoice
)或多选(mchoice
)问题,那么还有exams2nops
提供标准化格式,其中更简单使用(但也使用较少的自定义)。有关展示,请参阅:
exams2nops(c("anova.Rmd", "tstat2.Rmd"),
language = "pt", encoding = "UTF-8")
因此,您无法使用num
问题file.Rmd
。但如果您将其转换为schoice
问题,那么最大的优势就是您可以自动扫描并评估exams2nops
。
现在对于阿喀琉斯之踵:糟糕的文件。在我的辩护中,我不得不说在vignette("exams2", package = "exams")
的第2.3节(创建第一个考试)中简要讨论了编码问题,建议查看exams_skeleton()
的输出,看看它是如何工作的。所以在你的情况下
exams_skeleton(markup = "markdown", encoding = "UTF-8")
应该提供一些有用的例子。
但可以说这应该更容易找到。 exams
更好的文档网页在我的愿望清单中占据重要位置 - 特别是对于指导新人 - 但今年夏天我没有找到必要的时间。希望明年......
P.S。:Rmd文件开头的以下行完全没有必要,并被exams
忽略:
---
output: pdf_document
---
每个练习所呈现的输出由exams2
xyz 函数决定,而不是练习文件本身。例如:
exams2html("foo.Rmd", encoding = "UTF-8", template = "plain8")
函数(而不是Rmd文件)决定这一点的原因很简单:用户通常希望构建大量问题,然后可能希望在PDF中使用相同的问题文件(用于书面考试)或Moodle或通过ARSnova进行实时投票等。如果您每次都必须修改问题池(或保留副本),这将非常麻烦。