當前位置: 首頁>>代碼示例>>Python>>正文


Python tableschema.Schema方法代碼示例

本文整理匯總了Python中tableschema.Schema方法的典型用法代碼示例。如果您正苦於以下問題:Python tableschema.Schema方法的具體用法?Python tableschema.Schema怎麽用?Python tableschema.Schema使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在tableschema的用法示例。


在下文中一共展示了tableschema.Schema方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: schema_validator

# 需要導入模塊: import tableschema [as 別名]
# 或者: from tableschema import Schema [as 別名]
def schema_validator(resource, iterator,
                     field_names=None, on_error=None):
    if on_error is None:
        on_error = raise_exception
    on_error = wrap_handler(on_error)

    if isinstance(resource, Resource):
        schema: Schema = resource.schema
        assert schema is not None
        resource = resource.descriptor
    else:
        schema: Schema = Schema(resource.get('schema', {}))
    if field_names is None:
        field_names = [f.name for f in schema.fields]
    schema_fields = [f for f in schema.fields if f.name in field_names]
    for i, row in enumerate(iterator):
        field = None
        try:
            for field in schema_fields:
                row[field.name] = field.cast_value(row.get(field.name))
        except CastError as e:
            if not on_error(resource['name'], row, i, e, field):
                continue

        yield row 
開發者ID:datahq,項目名稱:dataflows,代碼行數:27,代碼來源:schema_validator.py

示例2: foreign_keys

# 需要導入模塊: import tableschema [as 別名]
# 或者: from tableschema import Schema [as 別名]
def foreign_keys(self):
        """Schema's foreign keys

        # Returns
            dict[]: foreign keys

        """
        foreign_keys = self.__current_descriptor.get('foreignKeys', [])
        for key in foreign_keys:
            key.setdefault('fields', [])
            key.setdefault('reference', {})
            key['reference'].setdefault('resource', '')
            key['reference'].setdefault('fields', [])
            if not isinstance(key['fields'], list):
                key['fields'] = [key['fields']]
            if not isinstance(key['reference']['fields'], list):
                key['reference']['fields'] = [key['reference']['fields']]
        return foreign_keys 
開發者ID:frictionlessdata,項目名稱:tableschema-py,代碼行數:20,代碼來源:schema.py

示例3: test_cast_row_too_short_handled

# 需要導入模塊: import tableschema [as 別名]
# 或者: from tableschema import Schema [as 別名]
def test_cast_row_too_short_handled():
    schema = Schema(DESCRIPTOR_MAX)
    source = ['string', '10.0', '1', 'string']
    # Missing values get substituted by None
    target = ['string', Decimal(10.0), 1, 'string', None]
    errors = []
    def handler(exc, row_number, row_data, error_data):
        errors.append((exc, row_number, row_data, error_data))
    assert schema.cast_row(source, exc_handler=handler) == target
    assert len(errors) == 1
    expect_row_data = OrderedDict(
        [('id', 'string'), ('height', '10.0'), ('age', '1'),
         ('name', 'string'), ('occupation', None)])
    _check_error(
        errors[0], expect_exc_class=exceptions.CastError,
        expect_exc_str='Row length', expect_row_number=None,
        expect_row_data=expect_row_data, expect_error_data=expect_row_data) 
開發者ID:frictionlessdata,項目名稱:tableschema-py,代碼行數:19,代碼來源:test_schema.py

示例4: test_cast_row_wrong_type_handled

# 需要導入模塊: import tableschema [as 別名]
# 或者: from tableschema import Schema [as 別名]
def test_cast_row_wrong_type_handled():
    schema = Schema(DESCRIPTOR_MAX)
    source = ['string', 'notdecimal', '1', 'string', 'string']
    target = ['string', 'notdecimal', 1, 'string', 'string']
    errors = []
    def handler(exc, row_number, row_data, error_data):
        errors.append((exc, row_number, row_data, error_data))
    actual = schema.cast_row(source, exc_handler=handler)
    assert actual == target
    assert isinstance(actual[1], FailedCast)
    assert len(errors) == 1
    expect_row_data = OrderedDict(
        [('id', 'string'), ('height', 'notdecimal'), ('age', '1'),
         ('name', 'string'), ('occupation', 'string')])
    expect_error_data = OrderedDict([('height', 'notdecimal')])
    _check_error(
        errors[0], expect_exc_class=exceptions.CastError,
        expect_exc_str='There are 1 cast errors', expect_row_number=None,
        expect_row_data=expect_row_data, expect_error_data=expect_error_data)
    exc = errors[0][0]
    assert len(exc.errors) == 1 
開發者ID:frictionlessdata,項目名稱:tableschema-py,代碼行數:23,代碼來源:test_schema.py

示例5: test_cast_row_wrong_type_multiple_errors_handled

# 需要導入模塊: import tableschema [as 別名]
# 或者: from tableschema import Schema [as 別名]
def test_cast_row_wrong_type_multiple_errors_handled():
    schema = Schema(DESCRIPTOR_MAX)
    source = ['string', 'notdecimal', '10.6', 'string', 'string']
    target = ['string', 'notdecimal', '10.6', 'string', 'string']
    errors = []
    def handler(exc, row_number, row_data, error_data):
        errors.append((exc, row_number, row_data, error_data))
    actual = schema.cast_row(source, exc_handler=handler)
    assert actual == target
    assert isinstance(actual[1], FailedCast)
    assert isinstance(actual[2], FailedCast)
    assert len(errors) == 1
    expect_row_data = OrderedDict(
        [('id', 'string'), ('height', 'notdecimal'), ('age', '10.6'),
         ('name', 'string'), ('occupation', 'string')])
    expect_error_data = OrderedDict(
        [('height', 'notdecimal'),('age', '10.6')])
    _check_error(
        errors[0], expect_exc_class=exceptions.CastError,
        expect_exc_str='There are 2 cast errors', expect_row_number=None,
        expect_row_data=expect_row_data, expect_error_data=expect_error_data)
    exc = errors[0][0]
    assert len(exc.errors) == 2 
開發者ID:frictionlessdata,項目名稱:tableschema-py,代碼行數:25,代碼來源:test_schema.py

示例6: iter

# 需要導入模塊: import tableschema [as 別名]
# 或者: from tableschema import Schema [as 別名]
def iter(self, bucket):

        # Get table and fallbacks
        table = self.__get_table(bucket)
        schema = tableschema.Schema(self.describe(bucket))
        autoincrement = self.__get_autoincrement_for_bucket(bucket)

        # Open and close transaction
        with self.__connection.begin():
            # Streaming could be not working for some backends:
            # http://docs.sqlalchemy.org/en/latest/core/connections.html
            select = table.select().execution_options(stream_results=True)
            result = select.execute()
            for row in result:
                row = self.__mapper.restore_row(
                    row, schema=schema, autoincrement=autoincrement)
                yield row 
開發者ID:frictionlessdata,項目名稱:tableschema-sql-py,代碼行數:19,代碼來源:storage.py

示例7: check_headers

# 需要導入模塊: import tableschema [as 別名]
# 或者: from tableschema import Schema [as 別名]
def check_headers(self, cells, sample):
        errors = []

        for cell in copy(cells):

            # Skip if cell has field
            if 'field' in cell and cell['field'] is not None:
                continue

            # Infer field
            if self.__infer_fields:
                column_sample = []
                for row in sample:
                    value = None
                    if len(row) >= cell['column-number']:
                        value = row[cell['column-number'] - 1]
                    column_sample.append([value])
                schema = Schema()
                schema.infer(column_sample, headers=[cell.get('header')])
                cell['field'] = schema.fields[0]

            # Add error/remove column
            else:
                message_substitutions = {
                    'header': '"{}"'.format(cell.get('header')),
                }
                error = Error(
                    'extra-header',
                    cell,
                    message_substitutions=message_substitutions
                )
                errors.append(error)
                cells.remove(cell)

        return errors 
開發者ID:frictionlessdata,項目名稱:goodtables-py,代碼行數:37,代碼來源:extra_header.py

示例8: table

# 需要導入模塊: import tableschema [as 別名]
# 或者: from tableschema import Schema [as 別名]
def table(source, schema=None, **options):
    warnings = []
    tables = []

    # Ensure not a datapackage
    if isinstance(source, six.string_types):
        if source.endswith('datapackage.json'):
            warnings.append('Use "datapackage" preset for Data Packages')

    # Prepare schema
    if not warnings:
        if schema is not None:
            try:
                schema = Schema(schema)
            except exceptions.TableSchemaException as error:
                warnings.append(
                    'Table Schema "%s" has a loading error "%s"' %
                    (schema, error))

    # Add table
    if not warnings:
        options.setdefault('headers', 1)
        tables.append({
            'source': str(source) if isinstance(source, six.string_types) else 'inline',
            'stream': Stream(source, **options),
            'schema': schema,
            'extra': {},
        })

    return warnings, tables 
開發者ID:frictionlessdata,項目名稱:goodtables-py,代碼行數:32,代碼來源:table.py

示例9: __infer

# 需要導入模塊: import tableschema [as 別名]
# 或者: from tableschema import Schema [as 別名]
def __infer(self, sample, headers=None):
        if headers is None:
            headers = [None] * len(sample[0]) if sample else []
        schema = tableschema.Schema()
        schema.infer(sample, headers=headers)
        return schema 
開發者ID:frictionlessdata,項目名稱:goodtables-py,代碼行數:8,代碼來源:inspector.py

示例10: descriptor

# 需要導入模塊: import tableschema [as 別名]
# 或者: from tableschema import Schema [as 別名]
def descriptor(self):
        """Schema's descriptor

        # Returns
            dict: descriptor

        """
        # Never use this.descriptor inside this class (!!!)
        return self.__next_descriptor 
開發者ID:frictionlessdata,項目名稱:tableschema-py,代碼行數:11,代碼來源:schema.py

示例11: missing_values

# 需要導入模塊: import tableschema [as 別名]
# 或者: from tableschema import Schema [as 別名]
def missing_values(self):
        """Schema's missing values

        # Returns
            str[]: missing values

        """
        return self.__current_descriptor.get('missingValues', []) 
開發者ID:frictionlessdata,項目名稱:tableschema-py,代碼行數:10,代碼來源:schema.py

示例12: primary_key

# 需要導入模塊: import tableschema [as 別名]
# 或者: from tableschema import Schema [as 別名]
def primary_key(self):
        """Schema's primary keys

        # Returns
            str[]: primary keys

        """
        primary_key = self.__current_descriptor.get('primaryKey', [])
        if not isinstance(primary_key, list):
            primary_key = [primary_key]
        return primary_key 
開發者ID:frictionlessdata,項目名稱:tableschema-py,代碼行數:13,代碼來源:schema.py

示例13: fields

# 需要導入模塊: import tableschema [as 別名]
# 或者: from tableschema import Schema [as 別名]
def fields(self):
        """Schema's fields

        # Returns
            Field[]: an array of field instances

        """
        return self.__fields 
開發者ID:frictionlessdata,項目名稱:tableschema-py,代碼行數:10,代碼來源:schema.py

示例14: test_infer_schema

# 需要導入模塊: import tableschema [as 別名]
# 或者: from tableschema import Schema [as 別名]
def test_infer_schema():
    runner = CliRunner()
    result = runner.invoke(infer, ['data/data_infer.csv'])
    # output is a string, evaluate to a dict
    schema = ast.literal_eval(result.output)
    schema_model = Schema(schema)
    assert schema_model.get_field('id').type == 'integer'
    assert schema_model.get_field('age').type == 'integer'
    assert schema_model.get_field('name').type == 'string' 
開發者ID:frictionlessdata,項目名稱:tableschema-py,代碼行數:11,代碼來源:test_cli.py

示例15: test_infer_schema_utf8

# 需要導入模塊: import tableschema [as 別名]
# 或者: from tableschema import Schema [as 別名]
def test_infer_schema_utf8():
    """UTF8 encoded data containing non-ascii characters."""
    runner = CliRunner()
    result = runner.invoke(infer, ['data/data_infer_utf8.csv'])
    # output is a string, evaluate to a dict
    schema = ast.literal_eval(result.output)
    schema_model = Schema(schema)
    assert schema_model.get_field('id').type == 'integer'
    assert schema_model.get_field('age').type == 'integer'
    assert schema_model.get_field('name').type == 'string' 
開發者ID:frictionlessdata,項目名稱:tableschema-py,代碼行數:12,代碼來源:test_cli.py


注:本文中的tableschema.Schema方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。