Class

io.eels.datastream

DataStreamPublisher

Related Doc: package datastream

Permalink

class DataStreamPublisher extends DataStream

An implementation of DataStream for which items are emitted by calling publish. When no more items are to be published, call close() so that downstream subscribers can complete.

Subscribers to this publisher will block as normal, and so they should normally be placed into a separate thread.

Linear Supertypes
DataStream, Logging, AnyRef, Any
Ordering
  1. Alphabetic
  2. By Inheritance
Inherited
  1. DataStreamPublisher
  2. DataStream
  3. Logging
  4. AnyRef
  5. Any
  1. Hide All
  2. Show All
Visibility
  1. Public
  2. All

Instance Constructors

  1. new DataStreamPublisher(schema: StructType)

    Permalink

Value Members

  1. final def !=(arg0: Any): Boolean

    Permalink
    Definition Classes
    AnyRef → Any
  2. final def ##(): Int

    Permalink
    Definition Classes
    AnyRef → Any
  3. def ++(other: DataStream): DataStream

    Permalink

    Joins two streams together, such that the elements of the given datastream are appended to the end of this datastream.

    Joins two streams together, such that the elements of the given datastream are appended to the end of this datastream.

    Definition Classes
    DataStream
  4. final def ==(arg0: Any): Boolean

    Permalink
    Definition Classes
    AnyRef → Any
  5. def addField(field: Field, defaultValue: Any): DataStream

    Permalink

    Returns a new DataStream with the given field added at the end.

    Returns a new DataStream with the given field added at the end. The value of this field for each Row is specified by the default value. The value must be compatible with the field definition. Eg, an error will occur if the field has type Int and the default value was 1.3

    Definition Classes
    DataStream
  6. def addField(name: String, defaultValue: String): DataStream

    Permalink

    Returns a new DataStream with the new field of type String added at the end.

    Returns a new DataStream with the new field of type String added at the end. The value of this field for each Row is specified by the default value.

    Definition Classes
    DataStream
  7. def addField(name: String, fn: (Row) ⇒ Any): DataStream

    Permalink

    Returns a new DataStream with a new field added.

    Returns a new DataStream with a new field added. The value for the field is taken from the function which is invoked for each row.

    Definition Classes
    DataStream
  8. def addField(field: Field, fn: (Row) ⇒ Any): DataStream

    Permalink

    Returns a new DataStream with a new field added.

    Returns a new DataStream with a new field added. The value for the field is taken from the function which is invoked for each row.

    Definition Classes
    DataStream
  9. def addFieldIfNotExists(field: Field, defaultValue: Any): DataStream

    Permalink
    Definition Classes
    DataStream
  10. def addFieldIfNotExists(name: String, defaultValue: Any): DataStream

    Permalink
    Definition Classes
    DataStream
  11. def aggregated(): GroupedDataStream

    Permalink
    Definition Classes
    DataStream
  12. final def asInstanceOf[T0]: T0

    Permalink
    Definition Classes
    Any
  13. def cartesian(other: DataStream): DataStream

    Permalink

    Returns a new DataStream which is the result of joining every row in this datastream with every row in the given datastream.

    Returns a new DataStream which is the result of joining every row in this datastream with every row in the given datastream.

    The given datastream will be materialized before it is used.

    For example, if this datastream has rows [a,b], [c,d] and [e,f] and the given datastream has [1,2] and [3,4] then the result will be [a,b,1,2], [a,b,3,4], [c,d,1,2], [c,d,3,4], [e,f,1,2] and [e,f,3,4].

    Definition Classes
    DataStream
  14. def clone(): AnyRef

    Permalink
    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  15. def close(): Unit

    Permalink
  16. def collect: Vector[Row]

    Permalink

    Action which results in all the rows being returned in memory as a Vector.

    Action which results in all the rows being returned in memory as a Vector.

    Definition Classes
    DataStream
  17. def concat(other: DataStream): DataStream

    Permalink

    Combines two datastreams together such that the fields from this datastream are joined with the fields of the given datastream.

    Combines two datastreams together such that the fields from this datastream are joined with the fields of the given datastream. Eg, if this datastream has fields A,B and the given datastream has fields C,D then the result will have fields A,B,C,D

    This operation requires an executor, as it must buffer rows to ensure an even distribution.

    Definition Classes
    DataStream
  18. def count: Long

    Permalink
    Definition Classes
    DataStream
  19. def drop(n: Int): DataStream

    Permalink
    Definition Classes
    DataStream
  20. def dropField(fieldName: String, caseSensitive: Boolean = true): DataStream

    Permalink
    Definition Classes
    DataStream
  21. def dropFieldIfExists(fieldName: String, caseSensitive: Boolean = true): DataStream

    Permalink
    Definition Classes
    DataStream
  22. def dropFields(regex: Regex): DataStream

    Permalink
    Definition Classes
    DataStream
  23. def dropNullRows(): DataStream

    Permalink
    Definition Classes
    DataStream
  24. def dropWhile(fieldName: String, p: (Any) ⇒ Boolean): DataStream

    Permalink
    Definition Classes
    DataStream
  25. def dropWhile(p: (Row) ⇒ Boolean): DataStream

    Permalink
    Definition Classes
    DataStream
  26. final def eq(arg0: AnyRef): Boolean

    Permalink
    Definition Classes
    AnyRef
  27. def equals(arg0: Any): Boolean

    Permalink
    Definition Classes
    AnyRef → Any
  28. def error(t: Throwable): Unit

    Permalink
  29. def exists(p: (Row) ⇒ Boolean): Boolean

    Permalink
    Definition Classes
    DataStream
  30. def explode(fn: (Row) ⇒ Seq[Row]): DataStream

    Permalink
    Definition Classes
    DataStream
  31. def filter(fieldName: String, p: (Any) ⇒ Boolean): DataStream

    Permalink

    Filters where the given field name matches the given predicate.

    Filters where the given field name matches the given predicate.

    Definition Classes
    DataStream
  32. def filter(f: (Row) ⇒ Boolean): DataStream

    Permalink
    Definition Classes
    DataStream
  33. def filterNot(p: (Row) ⇒ Boolean): DataStream

    Permalink
    Definition Classes
    DataStream
  34. def finalize(): Unit

    Permalink
    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( classOf[java.lang.Throwable] )
  35. def find(p: (Row) ⇒ Boolean): Option[Row]

    Permalink
    Definition Classes
    DataStream
  36. def foreach[U](fn: (Row) ⇒ U): DataStream

    Permalink

    Execute a side effecting function for every row in the stream, returning the same row.

    Execute a side effecting function for every row in the stream, returning the same row.

    Definition Classes
    DataStream
  37. final def getClass(): Class[_]

    Permalink
    Definition Classes
    AnyRef → Any
  38. def groupBy(fn: (Row) ⇒ Any): GroupedDataStream

    Permalink
    Definition Classes
    DataStream
  39. def groupBy(fields: Iterable[String]): GroupedDataStream

    Permalink
    Definition Classes
    DataStream
  40. def groupBy(first: String, rest: String*): GroupedDataStream

    Permalink
    Definition Classes
    DataStream
  41. def hashCode(): Int

    Permalink
    Definition Classes
    AnyRef → Any
  42. def head: Row

    Permalink
    Definition Classes
    DataStream
  43. def intersection(stream: DataStream): DataStream

    Permalink
    Definition Classes
    DataStream
  44. def isCancelled: Boolean

    Permalink
  45. final def isInstanceOf[T0]: Boolean

    Permalink
    Definition Classes
    Any
  46. def iterator: Iterator[Row]

    Permalink
    Definition Classes
    DataStream
  47. def join(key: String, other: DataStream): DataStream

    Permalink

    Joins the given datastream to this datastream on the given key column, where the values of the keys are equal as taken by the scala == operator.

    Joins the given datastream to this datastream on the given key column, where the values of the keys are equal as taken by the scala == operator. Both datastreams must contain the key column.

    The given datastream is fully inflated when this datastream needs to be materialized. For that reason, always use the smallest datastream as the parameter, and the larger datastream as the receiver.

    Definition Classes
    DataStream
  48. def listener(_listener: Listener): DataStream

    Permalink
    Definition Classes
    DataStream
  49. val logger: Logger

    Permalink
    Attributes
    protected
    Definition Classes
    Logging
  50. def map(f: (Row) ⇒ Row): DataStream

    Permalink
    Definition Classes
    DataStream
  51. def mapField(fieldName: String, fn: (Any) ⇒ Any): DataStream

    Permalink
    Definition Classes
    DataStream
  52. def mapFieldIfExists(fieldName: String, fn: (Any) ⇒ Any): DataStream

    Permalink
    Definition Classes
    DataStream
  53. def maxBy[T](fn: (Row) ⇒ T)(implicit ordering: Ordering[T]): Row

    Permalink
    Definition Classes
    DataStream
  54. def minBy[T](fn: (Row) ⇒ T)(implicit ordering: Ordering[T]): Row

    Permalink
    Definition Classes
    DataStream
  55. def multiplex(count: Int): Seq[DataStream]

    Permalink
    Definition Classes
    DataStream
  56. final def ne(arg0: AnyRef): Boolean

    Permalink
    Definition Classes
    AnyRef
  57. final def notify(): Unit

    Permalink
    Definition Classes
    AnyRef
  58. final def notifyAll(): Unit

    Permalink
    Definition Classes
    AnyRef
  59. def projection(fields: Seq[String]): DataStream

    Permalink

    Returns a new DataStream which contains the given list of fields from the existing stream.

    Returns a new DataStream which contains the given list of fields from the existing stream.

    Definition Classes
    DataStream
  60. def projection(first: String, rest: String*): DataStream

    Permalink
    Definition Classes
    DataStream
  61. def projectionExpression(expr: String): DataStream

    Permalink
    Definition Classes
    DataStream
  62. def publish(row: Seq[Row]): Unit

    Permalink
  63. def removeField(fieldName: String, caseSensitive: Boolean = true): DataStream

    Permalink
    Definition Classes
    DataStream
  64. def removeFieldIfExists(fieldName: String, caseSensitive: Boolean = true): DataStream

    Permalink
    Definition Classes
    DataStream
  65. def removeFields(regex: Regex): DataStream

    Permalink
    Definition Classes
    DataStream
  66. def renameField(nameFrom: String, nameTo: String): DataStream

    Permalink
    Definition Classes
    DataStream
  67. def replace(from: String, target: Any): DataStream

    Permalink

    For each row, any values that match "from" will be replaced with "target".

    For each row, any values that match "from" will be replaced with "target". This operation applies to all values for all rows.

    Definition Classes
    DataStream
  68. def replace(fieldName: String, from: String, target: Any): DataStream

    Permalink

    Replaces any values that match "form" with the value "target".

    Replaces any values that match "form" with the value "target". This operation only applies to the field name specified.

    Definition Classes
    DataStream
  69. def replace(fieldName: String, fn: (Any) ⇒ Any): DataStream

    Permalink
    Definition Classes
    DataStream
  70. def replaceField(name: String, field: Field): DataStream

    Permalink
    Definition Classes
    DataStream
  71. def replaceFieldType(regex: Regex, datatype: DataType): DataStream

    Permalink
    Definition Classes
    DataStream
  72. def replaceFieldType(from: DataType, to: DataType): DataStream

    Permalink
    Definition Classes
    DataStream
  73. def replaceFieldType(fieldName: String, datatype: DataType): DataStream

    Permalink

    Returns the same data but with an updated schema.

    Returns the same data but with an updated schema. The field that matches the given name will have its datatype set to the given datatype.

    Definition Classes
    DataStream
  74. def replaceNullValues(defaultValue: String): DataStream

    Permalink
    Definition Classes
    DataStream
  75. def sample(k: Int): DataStream

    Permalink

    Returns a new DataStream where only each "k" row is retained.

    Returns a new DataStream where only each "k" row is retained. Ie, if sample is 2, then on average, every other row will be returned. If sample is 10 then only 10% of rows will be returned. When running concurrently, the rows that are sampled will vary depending on the ordering that the workers pull through the rows. Each partition uses its own couter.

    Definition Classes
    DataStream
  76. val schema: StructType

    Permalink
    Definition Classes
    DataStreamPublisherDataStream
  77. def size: Long

    Permalink
    Definition Classes
    DataStream
  78. def stripCharsFromFieldNames(chars: Seq[Char]): DataStream

    Permalink

    Returns a new DataStream with the same data as this stream, but where the field names have been sanitized by removing any occurances of the given characters.

    Returns a new DataStream with the same data as this stream, but where the field names have been sanitized by removing any occurances of the given characters.

    Definition Classes
    DataStream
  79. def subscribe(subscriber: Subscriber[Seq[Row]]): Unit

    Permalink
    Definition Classes
    DataStreamPublisherDataStream
  80. def substract(stream: DataStream): DataStream

    Permalink
    Definition Classes
    DataStream
  81. final def synchronized[T0](arg0: ⇒ T0): T0

    Permalink
    Definition Classes
    AnyRef
  82. def take(n: Int): DataStream

    Permalink
    Definition Classes
    DataStream
  83. def takeWhile(fieldName: String, p: (Any) ⇒ Boolean): DataStream

    Permalink
    Definition Classes
    DataStream
  84. def takeWhile(p: (Row) ⇒ Boolean): DataStream

    Permalink
    Definition Classes
    DataStream
  85. def tee(schema: StructType, fn: (Row) ⇒ Seq[Row]): (DataStream, DataStream)

    Permalink

    Invoking this method returns two DataStreams.

    Invoking this method returns two DataStreams. The first is the original datastream which will continue as is. The second is a DataStream which is fed by rows generated from the given function. The function is invoked for each row that passes through this stream.

    Cancellation requests in the tee'd datastream do not propagate back to the original stream.

    Definition Classes
    DataStream
  86. def to(sink: Sink, parallelism: Int): Long

    Permalink
    Definition Classes
    DataStream
  87. def to(sink: Sink): Long

    Permalink
    Definition Classes
    DataStream
  88. def toDataTable: DataTable

    Permalink
    Definition Classes
    DataStream
  89. def toSet: Set[Row]

    Permalink
    Definition Classes
    DataStream
  90. def toString(): String

    Permalink
    Definition Classes
    AnyRef → Any
  91. def toVector: Vector[Row]

    Permalink

    Action which results in all the rows being returned in memory as a Vector.

    Action which results in all the rows being returned in memory as a Vector. Alias for 'collect()'

    Definition Classes
    DataStream
  92. def union(other: DataStream): DataStream

    Permalink
    Definition Classes
    DataStream
  93. def update(fieldName: String, fn: (Any) ⇒ Any): DataStream

    Permalink

    For each row, the value corresponding to the given fieldName is applied to the function.

    For each row, the value corresponding to the given fieldName is applied to the function. The result of the function is the new value for that cell.

    Definition Classes
    DataStream
  94. final def wait(): Unit

    Permalink
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  95. final def wait(arg0: Long, arg1: Int): Unit

    Permalink
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  96. final def wait(arg0: Long): Unit

    Permalink
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  97. def withLowerCaseSchema(): DataStream

    Permalink
    Definition Classes
    DataStream

Inherited from DataStream

Inherited from Logging

Inherited from AnyRef

Inherited from Any

Ungrouped