Please Download the package file at the end of the dicussion
Wolfram Langue developers and Mathematica users are all over the world and speak different languages. Automatic translation of their notebooks contents, even partial, would be very handy for these creators to share their works to audiens from varies background.
I will illustrate how you can create a palette with simple GUI to tranlate the content in a text cell automatically based on external Azure Cognitive Service. Though the following example is based on MS Translation, any Cognitive Service with Restful API can be configured in the same way in Wolfram Language.
Besides Mathematica, You will need
- a free Azure account
- API key for Cognitive Service
Once you are done with these configuration, you can follow the instruction below to create an one-click smart bi-directional translator in Mathematica.
For example,
- one-click from English to ZH-CHS
data:image/s3,"s3://crabby-images/33d58/33d58d8438aada9ef0e0bc6bb150ea1d2db47ca8" alt="entozh"
- One-click from ZH-CHS to English
data:image/s3,"s3://crabby-images/0e365/0e365fd5484e2111f0ef3b2bc903560bd116e221" alt="zhtoen"
The features covered here:
- ServiceConnect -- core functionality
- Notebook Manipulation -- content extraction
- CreatePalette function -- user interface
Core
A wrapper function is defined for ServiceConnect
to make an API call and do the translation between ZH-CHS and English/en
MSTranslatorService[txt_String,direction_] := Module[{langlist,translationDs},
...
langlist=<|"From"->"zh-CHS","To"->"en"|>
translationDs = ServiceExecute["MicrosoftTranslator", "GetTranslations", {
"Text" -> txt,
"From" -> langlist["From"],
"To" -> langlist["To"],
"MaxTranslations" -> "5"
}
];
translationDs[All,"TranslatedText"][[1]],$Failed];
A test function is created at same time. It just makes a simple call to the MSTranslateService
to translate "Hello" to ZH-CHS, which of course works assuming the connection is configured properly.
Notebook Manipulation
You need to break down the action before you can program something to automatically extract the content of the cell from a notebook
- Use the notebook I want to paste texual content, call
InputNotebook[]
You paste the textual content into the InputNotebook[]
. Then you click the translation button immediately after paste. For FrontEnd
, You are still selecting the last cell. Thus the following code works:
cell = NotebookRead[SelectedCells[InputNotebook[]][[1]]]/.{ Cell[txt_, type_, __]/;MemberQ[{"Text,Title,Subsection"},type] :> {txt,type}}},
The rule appended is to tell Mathematica that I only want to translate cells with Text, Title or Subsection StyleData
.
You have extracted the textual content of the cell and then print the translated text inside a window, which is sitting below the current texual cell
SelectionMove[InputNotebook[], Next, Cell];
ReleaseHold[Hold[NotebookWrite[InputNotebook[],Cell[BoxData[MakeBoxes[
DocumentNotebook[{temp}]]],"Text"]]]
/.temp->TextCell[MSTranslatorService[cell[[1]],dir],cell[[2]]]]
The key here is that you must pass a low level Cell[BoxData[MakeBoxes[ ... ]]]
object back to the InputNotebook
object.
Palette
Everything you have created above are wrapped in
CreatePalette[{ ExpressionCell[.DynamicModule[{ }, ... }] ] }]
Use DynamicModule
here because all actions are controlled by Button
and RadioButton
. They require Dynamic
function to wrap around what gets updated upon click.
DynamicModule[{dir},
...
RadioButtonBar[Dynamic[dir],{"FromZH","ToZH"} ],
Dynamic@Button["Translate",
SelectionMove[InputNotebook[], All, CellContents];
(* Code in Notebook Manipulation section *?
Feel free to use Panel, Colum and Grid to align the controls in a visually-pleasing way.
Attachments: