如何使用带有葡萄牙语口音的R包考试?

时间:2016-09-08 04:22:30

标签: r latex r-markdown r-exams

当我使用包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编译正确显示重音:

compilation with RStudio

但是当我尝试时:

exams2pdf('file.Rmd', encoding = 'utf8')

它不起作用。

compilation with function exams()

有人可以帮我解决这个问题吗?

2 个答案:

答案 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的templateexams软件包附带一个简单的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进行实时投票等。如果您每次都必须修改问题池(或保留副本),这将非常麻烦。