imdb_reader.py 2.8 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13
#   Copyright (c) 2018 PaddlePaddle Authors. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
#     http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
B
barrierye 已提交
14
# pylint: disable=doc-string-missing
15 16 17 18 19 20 21

import sys
import os
import paddle
import re
import paddle.fluid.incubate.data_generator as dg

B
barrierye 已提交
22

23 24 25 26 27 28 29 30 31 32 33 34
class IMDBDataset(dg.MultiSlotDataGenerator):
    def load_resource(self, dictfile):
        self._vocab = {}
        wid = 0
        with open(dictfile) as f:
            for line in f:
                self._vocab[line.strip()] = wid
                wid += 1
        self._unk_id = len(self._vocab)
        self._pattern = re.compile(r'(;|,|\.|\?|!|\s|\(|\))')
        self.return_value = ("words", [1, 2, 3, 4, 5, 6]), ("label", [0])

35 36 37 38 39 40 41 42
    def get_words_only(self, line):
        sent = line.lower().replace("<br />", " ").strip()
        words = [x for x in self._pattern.split(sent) if x and x != " "]
        feas = [
            self._vocab[x] if x in self._vocab else self._unk_id for x in words
        ]
        return feas

43 44 45 46
    def get_words_and_label(self, line):
        send = '|'.join(line.split('|')[:-1]).lower().replace("<br />",
                                                              " ").strip()
        label = [int(line.split('|')[-1])]
B
barrierye 已提交
47

48 49 50 51 52 53 54 55 56 57 58 59 60
        words = [x for x in self._pattern.split(send) if x and x != " "]
        feas = [
            self._vocab[x] if x in self._vocab else self._unk_id for x in words
        ]
        return feas, label

    def infer_reader(self, infer_filelist, batch, buf_size):
        def local_iter():
            for fname in infer_filelist:
                with open(fname, "r") as fin:
                    for line in fin:
                        feas, label = self.get_words_and_label(line)
                        yield feas, label
B
barrierye 已提交
61

62 63
        import paddle
        batch_iter = paddle.batch(
B
barrierye 已提交
64 65
            paddle.reader.shuffle(
                local_iter, buf_size=buf_size),
66 67 68 69 70 71 72
            batch_size=batch)
        return batch_iter

    def generate_sample(self, line):
        def memory_iter():
            for i in range(1000):
                yield self.return_value
B
barrierye 已提交
73

74 75 76
        def data_iter():
            feas, label = self.get_words_and_label(line)
            yield ("words", feas), ("label", label)
B
barrierye 已提交
77

78 79
        return data_iter

B
barrierye 已提交
80

81 82 83 84
if __name__ == "__main__":
    imdb = IMDBDataset()
    imdb.load_resource("imdb.vocab")
    imdb.run_from_stdin()