xtr*_*3me 3 tensorflow tensorflow-datasets
我目前正在使用 Tensorflow 数据集 api 对指定路径上的图像执行一些增强。文件名本身包含说明是否扩充文件的信息。所以我想要做的是从数据集中读取文件,对于每个文件,在文件名中执行查找,如果找到特定的子字符串,则设置一个 bool 标志并将子字符串替换为“”。
我得到的错误是:
AttributeError: 'Tensor' 对象没有属性 'find'
我无法使用 dtype 字符串条目对张量执行“查找”,因为 find 不是张量的一部分,所以我试图弄清楚如何执行上述操作。我在下面分享了一些代码,我认为这些代码展示了我正在尝试做的事情。性能很重要,因此如果有人发现我将通过 Dataset API 错误地执行此操作,我更愿意以正确的方式执行此操作。
def preproc_img(filenames):
def parse_fn(filename):
augment_inst = False
if cfg.SPLIT_INTO_INST:
#*****************************************************
#*** THIS IS WHERE THE LOGIC IS CURRENTLY BREAKING ***
#*****************************************************
if filename.find('_data_augmentation') != -1:
augment_inst = True
filename = filename.replace('_data_augmentation', '')
image_string = tf.read_file(filename)
img = tf.image.decode_image(image_string, channels=3)
return dict(zip([filename], [img]))
dataset = tf.data.Dataset.from_tensor_slices(filenames)
dataset = dataset.map(parse_fn)
iterator = dataset.make_one_shot_iterator()
return iterator.get_next()
def perform_train():
if __name__ == '__main__':
filenames = helper.get_image_paths()
next_batch = preproc_img(filenames)
with tf.Session() as sess:
with sess .graph.as_default():
sess.run(tf.local_variables_initializer())
sess.run(tf.global_variables_initializer())
dat = sess.run(next_batch)
# I would now go about calling any of my tf op code below
Run Code Online (Sandbox Code Playgroud)
您可以tf.regex_replace
用于替换tf.string
张量中的文本。
filename = tf.regex_replace(filename, "_data_augmentation", "")
Run Code Online (Sandbox Code Playgroud)
对于 TF 2.0
filename = tf.strings.regex_replace(filename, "_data_augmentation", "")
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
4253 次 |
最近记录: |