如果有图会很好理解,最近太忙,以后再加吧
  1. #首先有一个需要读取的文件名列表
    #然后将文件名列表通过函数string_input_producer放进文件名队列。
    #有时候因为数据量太大,需要把他们放进不同的tfrecord文件中
    filename_queue = tf.train.string_input_producer(["file0.csv","file1.csv"])
    #对不同格式的文件有不同的reader
    reader = tf.TextLineReader()
    #通过reader的read函数extract a record from a file whose name is in the queue,
    #如果该文件中所有记录都被抽取完,dequeue这个filename,参考readerbase
    #read()返回下一个record
    key, value = reader.read(filename_queue)
    # decoded record,decode方式和文件内部record格式相关,然后拼接成需要的格式
    record_defaults =[[1],[1],[1],[1],[1]]
    col1, col2, col3, col4, col5 = tf.decode_csv(
    value, record_defaults=record_defaults)
    features = tf.stack([col1, col2, col3, col4])
    with tf.Session()as sess:
    # Start populating the filename queue.
    coord = tf.train.Coordinator()
    threads = tf.train.start_queue_runners(coord=coord)
    for i in range(1200):
    # Retrieve a single instance:
    example, label = sess.run([features, col5])
    coord.request_stop()
    coord.join(threads)

    参考:https://www.tensorflow.org/programmers_guide/reading_data


提到queue就不得不提两个帮助多线程异步的类:tf.train.Coordinator和tf.train.QueueRunner;
  • tf.train.Coordinator:控制多线程,使其同时结束。
  • tf.train.QueueRunner:包含一些enqueue op,为其create一些线程,每一个op都在一个线程上运行。

coordinator

Coordinator方法:should_stop,request_stop,join
    1.  # Thread body: loop until the coordinator indicates a stop was requested.
      # If some condition becomes true, ask the coordinator to stop.
      defMyLoop(coord):
      whilenot coord.should_stop():#should_stop返回true or false,表示线程是否该结束
      ...do something...
      if...some condition...:
      coord.request_stop()#当某些条件发生时,一个进程request_stop,其他进程因为should_stop返回true而终止
      # Main thread: create a coordinator.
      coord = tf.train.Coordinator()
      # Create 10 threads that run 'MyLoop()'
      threads =[threading.Thread(target=MyLoop, args=(coord,))for i in xrange(10)]
      # Start the threads and wait for all of them to stop.
      for t in threads:
      t.start()
      coord.join(threads)

QueueRunner

  1.  example =...ops to create one example...
    # Create a queue, and an op that enqueues examples one at a time in the queue.
    #区别于filename queue,这是example queue。可以是接着上面读数据解析然后放进这个queue
    queue = tf.RandomShuffleQueue(...)
    enqueue_op = queue.enqueue(example)#定义入队操作
    # Create a training graph that starts by dequeuing a batch of examples.
    inputs = queue.dequeue_many(batch_size)
    train_op =...use 'inputs' to build the training part of the graph...
    # Create a queue runner that will run 4 threads in parallel to enqueue
    # examples.
    #QueueRunner的构造函数,queuerunner是为一个queue的入队操作多线程化服务的,
    #第二个参数是入队操作列表
    qr = tf.train.QueueRunner(queue,[enqueue_op]*4)
    # Launch the graph.
    sess = tf.Session()
    # Create a coordinator, launch the queue runner threads.
    coord = tf.train.Coordinator()
    #queuerunner为queue创造多线程,并且把这些线程的结束交由coordinator管理
    enqueue_threads = qr.create_threads(sess, coord=coord, start=True)
    # Run the training loop, controlling termination with the coordinator.
    for step in xrange(1000000):
    if coord.should_stop():
    break
    sess.run(train_op)
    # When done, ask the threads to stop.
    coord.request_stop()
    # And wait for them to actually do it.
    coord.join(enqueue_threads)
未完待续。。。

reading from files的更多相关文章

  1. Reading Csv Files with Text_io in Oracle D2k Forms

    Below is the example to read and import comma delimited csv file in oracle forms with D2k_Delimited_ ...

  2. reading/writing files in Python

    file types: plaintext files, such as .txt .py Binary files, such as .docx, .pdf, iamges, spreadsheet ...

  3. Reading Text-based Files In ASP.NET

    Friday, July 17, 2015 1:43 PM Every time I need to work with the contents of text-based files in an ...

  4. PHP | Uploading and reading of files and database 【PHP | 文件的上传和读取与数据库】

    这是我自己的一个作业,用的是很基础的代码. 有错误的地方欢迎批评和指正! 这里最容易出错的地方在读取数据后向数据库表中插入数据是的数据格式! 文件上传的页面 uploading.php <htm ...

  5. Using Text_IO To Read Files in Oracle D2k

    Suppose you want to read a file from D2k client and want to store its content in Oracle database. Bu ...

  6. Fast data loading from files to R

    Recently we were building a Shiny App in which we had to load data from a very large dataframe. It w ...

  7. 解决javascript - node and Error: EMFILE, too many open files

    For some days I have searched for a working solution to an error Error: EMFILE, too many open files ...

  8. (转)使用 SCons 轻松建造程序

    在软件项目开发过程中,make 工具通常被用来建造程序.make 工具通过一个被称为 Makefile 的配置文件可以自动的检测文件之间的依赖关系,这对于建造复杂的项目非常有帮助,然而,编写 Make ...

  9. linux使用wkhtmltopdf报错error while loading shared libraries:

    官网提示 linux需要这些动态库.depends on: zlib, fontconfig, freetype, X11 libs (libX11, libXext, libXrender) 在li ...

随机推荐

  1. UVA11383 Golden Tiger Claw —— KM算法

    题目链接:https://vjudge.net/problem/UVA-11383 题解: 根据KM()算法,标杆满足:l(x) + l(y) >= w(x, y) . 当求完最大权匹配之后,所 ...

  2. 并不对劲的bzoj1500: [NOI2005]维修数列

    传送门-> 这题没什么好说的……小清新数据结构题……并不对劲的人太菜了,之前照着标程逐行比对才过了这道题,前几天刚刚把这题一遍写对…… 其实这题应该口胡很容易.操作1,2,3,4,5就是普通的s ...

  3. Python3中 对local和nonlocal 关键字的改善认识(新手向)

    nonlocal关键字用来在函数或其他作用域中使用外层(非全局)变量. nonlocal用于声明,修改嵌套作用域(enclosing 作用域,外层非全局作用域)中的变量,如下实例: #!/usr/bi ...

  4. hdu5335(搜索)

    Walk Out Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)Total Su ...

  5. 浅谈JAVA中如何利用socket进行网络编程(一)

    转自:http://developer.51cto.com/art/201106/268385.htm Socket是网络上运行的两个程序间双向通讯的一端,它既可以接受请求,也可以发送请求,利用它可以 ...

  6. 03_隐式意图打开activity

    想让第一个activity把第二个activity打开的话,在清单文件里面声明一下并且 右键Debug As Android Application居然没有报错 mimeType  讲HTML的时候就 ...

  7. SpringMVC数据绑定三(JSON 、XML))

    dhc chrome 地址https://chrome.google.com/webstore/detail/restlet-client-rest-api-t/aejoelaoggembcahagi ...

  8. 关于loadrunner运行场景时提示“初始化失败,通信错误”的解决方案

    1)在loadrunner的安装目录下的bin文件夹下有个“wlrun.exe”的文件 2)右键点击“属性”->"兼容性"->兼容模式中选择“windows xp(se ...

  9. error C2664: “CWnd::MessageBoxW”: 不能将参数 1 从“const char [17]”转换为“LPCTSTR”

    vs2008提示 error C2664: “CWnd::MessageBoxW”: 不能将参数 1 从“const char [17]”转换为“LPCTSTR” 在外面用vs2005编写mfc程序的 ...

  10. windows server 2003 修改远程链接端口

    服务器默认的远程链接的端口是3389,只能内网访问,外网不能访问,现映射了8400端口给服务器,内外网都可以访问,因此需要修改服务器的远程链接的端口. 运行中 输入:regedit 选择十进制,将33 ...