Hot-keys on this page

r m x p   toggle line displays

j k   next/prev highlighted chunk

0   (zero) top of page

1   (one) first highlighted chunk

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

93

94

95

96

97

98

99

100

101

102

103

104

105

106

107

108

109

110

111

112

113

114

115

116

117

118

119

120

121

122

123

124

125

126

127

128

129

130

#! /usr/bin/env python3 

# -*- coding: utf-8 -*- 

 

#       Copyright 2013, Marten de Vries 

# 

#       This file is part of OpenTeacher. 

# 

#       OpenTeacher is free software: you can redistribute it and/or modify 

#       it under the terms of the GNU General Public License as published by 

#       the Free Software Foundation, either version 3 of the License, or 

#       (at your option) any later version. 

# 

#       OpenTeacher is distributed in the hope that it will be useful, 

#       but WITHOUT ANY WARRANTY; without even the implied warranty of 

#       MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the 

#       GNU General Public License for more details. 

# 

#       You should have received a copy of the GNU General Public License 

#       along with OpenTeacher.  If not, see <http://www.gnu.org/licenses/>. 

 

import csv 

 

class CsvLoaderModule: 

        def __init__(self, moduleManager, *args, **kwargs): 

                super().__init__(*args, **kwargs) 

                self._mm = moduleManager 

 

                self.type = "load" 

                self.requires = ( 

                        self._mm.mods(type="wordsStringParser"), 

                ) 

                self.uses = ( 

                        self._mm.mods(type="translator"), 

                ) 

                self.filesWithTranslations = ("csv_.py",) 

 

        @property 

        def _parse(self): 

                return self._modules.default("active", type="wordsStringParser").parse 

 

        def getFileTypeOf(self, path): 

43                if path.endswith(".csv") or path.endswith(".tsv"): 

                        return "words" 

 

        def load(self, path): 

                with open(path, "rbU") as f: 

                        data = f.read() 

                encoding = chardet.detect(data)["encoding"] 

                unicodeData = data.decode(encoding=encoding, errors="ignore") 

 

                sniffer = csv.Sniffer() 

                dialect = sniffer.sniff(unicodeData) 

                reader = csv.reader(unicodeData.split("\n"), dialect) 

 

                items = [] 

                for i, line in enumerate(reader): 

                        if not line: 

                                continue 

                        try: 

                                questions = self._parse(line[0]) 

                                answers = self._parse(line[1]) 

                        except IndexError: 

                                continue 

 

                        items.append({ 

                                "id": i, 

                                "questions": questions, 

                                "answers": answers, 

                        }) 

 

                return { 

                        "resources": {}, 

                        "list": { 

                                "items": items, 

                                "tests": [], 

                        }, 

                } 

 

        def _retranslate(self): 

                try: 

                        translator = self._modules.default("active", type="translator") 

                except IndexError: 

exit                        _, ngettext = str, lambda a, b, n: a if n == 1 else b 

                else: 

                        _, ngettext = translator.gettextFunctions( 

                                self._mm.resourcePath("translations") 

                        ) 

                #TRANSLATORS: This is one of the file formats OpenTeacher can 

                #TRANSLATORS: read. 

                self.name = _("Spreadsheet") 

 

        def enable(self): 

                global chardet 

                try: 

                        import chardet 

                except ImportError: 

                        #fallback. Strongly recommended to use the real one, 

                        #though ;) 

                        class MyChardet: 

                                def detect(self, *args, **kwargs): 

                                        return {"encoding": "UTF-8"} 

                        chardet = MyChardet() 

 

                self.loads = { 

                        "csv": ["words"], 

                        "tsv": ["words"], 

                } 

                #no mimetype. Registering text/csv is too harsh. 

 

                self._modules = set(self._mm.mods(type="modules")).pop() 

                try: 

                        translator = self._modules.default("active", type="translator") 

                except IndexError: 

                        pass 

                else: 

                        translator.languageChanged.handle(self._retranslate) 

                self._retranslate() 

 

                self.active = True 

 

        def disable(self): 

                self.active = False 

 

                del self.name 

                del self.loads 

 

                del self._modules 

 

def init(moduleManager): 

        return CsvLoaderModule(moduleManager)