Struct google_api_proto::google::cloud::vision::v1p3beta1::ImportProductSetsGcsSource
source · pub struct ImportProductSetsGcsSource {
pub csv_file_uri: String,
}
Expand description
The Google Cloud Storage location for a csv file which preserves a list of ImportProductSetRequests in each line.
Fields§
§csv_file_uri: String
The Google Cloud Storage URI of the input csv file.
The URI must start with gs://
.
The format of the input csv file should be one image per line. In each line, there are 6 columns.
- image_uri 2, image_id
- product_set_id
- product_id 5, product_category 6, product_display_name 7, labels
- bounding_poly
Columns 1, 3, 4, and 5 are required, other columns are optional. A new ProductSet/Product with the same id will be created on the fly if the ProductSet/Product specified by product_set_id/product_id does not exist.
The image_id field is optional but has to be unique if provided. If it is empty, we will automatically assign an unique id to the image.
The product_display_name field is optional. If it is empty, a space (“ “) is used as the place holder for the product display_name, which can be updated later through the realtime API.
If the Product with product_id already exists, the fields product_display_name, product_category and labels are ignored.
If a Product doesn’t exist and needs to be created on the fly, the product_display_name field refers to [Product.display_name][google.cloud.vision.v1p3beta1.Product.display_name], the product_category field refers to [Product.product_category][google.cloud.vision.v1p3beta1.Product.product_category], and the labels field refers to [Product.labels][].
Labels (optional) should be a line containing a list of comma-separated key-value pairs, with the format “key_1=value_1,key_2=value_2,…,key_n=value_n”.
The bounding_poly (optional) field is used to identify one region of interest from the image in the same manner as CreateReferenceImage. If no bounding_poly is specified, the system will try to detect regions of interest automatically.
Note that the pipeline will resize the image if the image resolution is too large to process (above 20MP).
Also note that at most one bounding_poly is allowed per line. If the image contains multiple regions of interest, the csv should contain one line per region of interest.
The bounding_poly column should contain an even number of comma-separated numbers, with the format “p1_x,p1_y,p2_x,p2_y,…,pn_x,pn_y”. Nonnegative integers should be used for absolute bounding polygons, and float values in [0, 1] should be used for normalized bounding polygons.
Trait Implementations§
source§impl Clone for ImportProductSetsGcsSource
impl Clone for ImportProductSetsGcsSource
source§fn clone(&self) -> ImportProductSetsGcsSource
fn clone(&self) -> ImportProductSetsGcsSource
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moresource§impl Debug for ImportProductSetsGcsSource
impl Debug for ImportProductSetsGcsSource
source§impl Default for ImportProductSetsGcsSource
impl Default for ImportProductSetsGcsSource
source§impl Message for ImportProductSetsGcsSource
impl Message for ImportProductSetsGcsSource
source§fn encoded_len(&self) -> usize
fn encoded_len(&self) -> usize
source§fn encode(&self, buf: &mut impl BufMut) -> Result<(), EncodeError>where
Self: Sized,
fn encode(&self, buf: &mut impl BufMut) -> Result<(), EncodeError>where
Self: Sized,
source§fn encode_to_vec(&self) -> Vec<u8>where
Self: Sized,
fn encode_to_vec(&self) -> Vec<u8>where
Self: Sized,
source§fn encode_length_delimited(
&self,
buf: &mut impl BufMut,
) -> Result<(), EncodeError>where
Self: Sized,
fn encode_length_delimited(
&self,
buf: &mut impl BufMut,
) -> Result<(), EncodeError>where
Self: Sized,
source§fn encode_length_delimited_to_vec(&self) -> Vec<u8>where
Self: Sized,
fn encode_length_delimited_to_vec(&self) -> Vec<u8>where
Self: Sized,
source§fn decode(buf: impl Buf) -> Result<Self, DecodeError>where
Self: Default,
fn decode(buf: impl Buf) -> Result<Self, DecodeError>where
Self: Default,
source§fn decode_length_delimited(buf: impl Buf) -> Result<Self, DecodeError>where
Self: Default,
fn decode_length_delimited(buf: impl Buf) -> Result<Self, DecodeError>where
Self: Default,
source§fn merge(&mut self, buf: impl Buf) -> Result<(), DecodeError>where
Self: Sized,
fn merge(&mut self, buf: impl Buf) -> Result<(), DecodeError>where
Self: Sized,
self
. Read moresource§fn merge_length_delimited(&mut self, buf: impl Buf) -> Result<(), DecodeError>where
Self: Sized,
fn merge_length_delimited(&mut self, buf: impl Buf) -> Result<(), DecodeError>where
Self: Sized,
self
.source§impl PartialEq for ImportProductSetsGcsSource
impl PartialEq for ImportProductSetsGcsSource
source§fn eq(&self, other: &ImportProductSetsGcsSource) -> bool
fn eq(&self, other: &ImportProductSetsGcsSource) -> bool
self
and other
values to be equal, and is used
by ==
.impl StructuralPartialEq for ImportProductSetsGcsSource
Auto Trait Implementations§
impl Freeze for ImportProductSetsGcsSource
impl RefUnwindSafe for ImportProductSetsGcsSource
impl Send for ImportProductSetsGcsSource
impl Sync for ImportProductSetsGcsSource
impl Unpin for ImportProductSetsGcsSource
impl UnwindSafe for ImportProductSetsGcsSource
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
source§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
T
in a tonic::Request